
* add ascent package and and deps * proper use of site_packages_dir prop * flake8 * add maitain, small updates * flake8 * flake8 * fixs for docstrings for sphinx
126 lines
5.5 KiB
Python
126 lines
5.5 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/spack/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
|
|
##############################################################################
|
|
from spack import *
|
|
import glob
|
|
|
|
|
|
class IntelTbb(Package):
|
|
"""Widely used C++ template library for task parallelism.
|
|
Intel Threading Building Blocks (Intel TBB) lets you easily write parallel
|
|
C++ programs that take full advantage of multicore performance, that are
|
|
portable and composable, and that have future-proof scalability.
|
|
"""
|
|
homepage = "http://www.threadingbuildingblocks.org/"
|
|
|
|
# Only version-specific URL's work for TBB
|
|
version('2018.1', 'b2f2fa09adf44a22f4024049907f774b',
|
|
url='https://github.com/01org/tbb/archive/2018_U1.tar.gz')
|
|
version('2018.0', 'e54de69981905ad69eb9cf0226b9bf5f9a4ba065',
|
|
url='https://github.com/01org/tbb/archive/2018.tar.gz')
|
|
version('2017.8', '488f049fd107d8b1f6ba59cf4aad881172525106',
|
|
url='https://github.com/01org/tbb/archive/2017_U8.tar.gz')
|
|
version('2017.6', 'c0a722fd1ae66b40aeab25da6049086ef5f02f17',
|
|
url='https://github.com/01org/tbb/archive/2017_U6.tar.gz')
|
|
version('2017.5', '26f720729d322913912e99d1e4a36bd10625d3ca',
|
|
url='https://github.com/01org/tbb/archive/2017_U5.tar.gz')
|
|
version('2017.3', '2c451a5bcf6fc31487b98b4b29651c369874277c',
|
|
url='https://www.threadingbuildingblocks.org/sites/default/files/software_releases/source/tbb2017_20161128oss_src.tgz')
|
|
version('4.4.4', 'd4cee5e4ca75cab5181834877738619c56afeb71',
|
|
url='https://www.threadingbuildingblocks.org/sites/default/files/software_releases/source/tbb44_20160413oss_src.tgz')
|
|
version('4.4.3', '80707e277f69d9b20eeebdd7a5f5331137868ce1',
|
|
url='https://www.threadingbuildingblocks.org/sites/default/files/software_releases/source/tbb44_20160128oss_src_0.tgz')
|
|
|
|
provides('tbb')
|
|
|
|
# include patch for gcc rtm options
|
|
patch("tbb_gcc_rtm_key.patch", level=0)
|
|
|
|
def coerce_to_spack(self, tbb_build_subdir):
|
|
for compiler in ["icc", "gcc", "clang"]:
|
|
fs = glob.glob(join_path(tbb_build_subdir,
|
|
"*.%s.inc" % compiler))
|
|
for f in fs:
|
|
lines = open(f).readlines()
|
|
of = open(f, "w")
|
|
for l in lines:
|
|
if l.strip().startswith("CPLUS ="):
|
|
of.write("# coerced to spack\n")
|
|
of.write("CPLUS = $(CXX)\n")
|
|
elif l.strip().startswith("CPLUS ="):
|
|
of.write("# coerced to spack\n")
|
|
of.write("CONLY = $(CC)\n")
|
|
else:
|
|
of.write(l)
|
|
|
|
def install(self, spec, prefix):
|
|
if spec.satisfies('%gcc@6.1:') and spec.satisfies('@:4.4.3'):
|
|
raise InstallError('Only TBB 4.4.4 and above build with GCC 6.1!')
|
|
|
|
# We need to follow TBB's compiler selection logic to get the proper
|
|
# build + link flags but we still need to use spack's compiler wrappers
|
|
# to accomplish this, we do two things:
|
|
#
|
|
# * Look at the spack spec to determine which compiler we should pass
|
|
# to tbb's Makefile;
|
|
#
|
|
# * patch tbb's build system to use the compiler wrappers (CC, CXX) for
|
|
# icc, gcc, clang (see coerce_to_spack());
|
|
#
|
|
self.coerce_to_spack("build")
|
|
|
|
if spec.satisfies('%clang'):
|
|
tbb_compiler = "clang"
|
|
elif spec.satisfies('%intel'):
|
|
tbb_compiler = "icc"
|
|
else:
|
|
tbb_compiler = "gcc"
|
|
|
|
mkdirp(prefix)
|
|
mkdirp(prefix.lib)
|
|
|
|
#
|
|
# tbb does not have a configure script or make install target
|
|
# we simply call make, and try to put the pieces together
|
|
#
|
|
make("compiler=%s" % (tbb_compiler))
|
|
|
|
# install headers to {prefix}/include
|
|
install_tree('include', prefix.include)
|
|
|
|
# install libs to {prefix}/lib
|
|
tbb_lib_names = ["libtbb",
|
|
"libtbbmalloc",
|
|
"libtbbmalloc_proxy"]
|
|
|
|
for lib_name in tbb_lib_names:
|
|
# install release libs
|
|
fs = glob.glob(join_path("build", "*release", lib_name + ".*"))
|
|
for f in fs:
|
|
install(f, prefix.lib)
|
|
# install debug libs if they exist
|
|
fs = glob.glob(join_path("build", "*debug", lib_name + "_debug.*"))
|
|
for f in fs:
|
|
install(f, prefix.lib)
|