summaryrefslogtreecommitdiff
path: root/var
diff options
context:
space:
mode:
authorDenis Davydov <davydden@gmail.com>2016-07-13 10:50:57 +0200
committerDenis Davydov <davydden@gmail.com>2016-07-13 11:42:40 +0200
commit52ca215e2947f7fe5c5248ccbd5e4fa19c8536fd (patch)
tree4a6e4c7b1b4964a8d8611f23df5bbb1daa5b239a /var
parent069de3f00897b0108243539730c00a83ecb55f09 (diff)
downloadspack-52ca215e2947f7fe5c5248ccbd5e4fa19c8536fd.tar.gz
spack-52ca215e2947f7fe5c5248ccbd5e4fa19c8536fd.tar.bz2
spack-52ca215e2947f7fe5c5248ccbd5e4fa19c8536fd.tar.xz
spack-52ca215e2947f7fe5c5248ccbd5e4fa19c8536fd.zip
mkl: add provide blas/lapack
Diffstat (limited to 'var')
-rw-r--r--var/spack/repos/builtin/packages/mkl/package.py23
1 files changed, 23 insertions, 0 deletions
diff --git a/var/spack/repos/builtin/packages/mkl/package.py b/var/spack/repos/builtin/packages/mkl/package.py
index 454e78d29c..889851c953 100644
--- a/var/spack/repos/builtin/packages/mkl/package.py
+++ b/var/spack/repos/builtin/packages/mkl/package.py
@@ -18,6 +18,11 @@ class Mkl(IntelInstaller):
version('11.3.3.210', 'f72546df27f5ebb0941b5d21fd804e34',
url="file://%s/l_mkl_11.3.3.210.tgz" % os.getcwd())
+ # virtual dependency
+ provides('blas')
+ provides('lapack')
+ # TODO: MKL also provides implementation of Scalapack.
+
def install(self, spec, prefix):
self.intel_prefix = os.path.join(prefix, "pkg")
@@ -26,3 +31,21 @@ class Mkl(IntelInstaller):
mkl_dir = os.path.join(self.intel_prefix, "mkl")
for f in os.listdir(mkl_dir):
os.symlink(os.path.join(mkl_dir, f), os.path.join(self.prefix, f))
+
+ def setup_dependent_package(self, module, dspec):
+ # For now use Single Dynamic Library:
+ # To set the threading layer at run time, use the
+ # mkl_set_threading_layer function or set MKL_THREADING_LAYER
+ # variable to one of the following values: INTEL, SEQUENTIAL, PGI.
+ # To set interface layer at run time, use the mkl_set_interface_layer
+ # function or set the MKL_INTERFACE_LAYER variable to LP64 or ILP64.
+
+ # Otherwise one would need to specify several libraries
+ # (e.g. mkl_intel_lp64;mkl_sequential;mkl_core), which reflect
+ # different interface and threading layers.
+
+ name = 'libmkl_rt.%s' % dso_suffix
+ libdir = find_library_path(name, self.prefix.lib64, self.prefix.lib)
+
+ self.spec.blas_shared_lib = join_path(libdir, name)
+ self.spec.lapack_shared_lib = self.spec.blas_shared_lib