summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDaniele Cesarini <d.cesarini@cineca.it>2022-01-25 19:35:09 +0100
committerGitHub <noreply@github.com>2022-01-25 10:35:09 -0800
commit1f3f1100b321356ca765cfda7d3f40b350653519 (patch)
treea806565d92a3b48e8bdcd7385f2e95ddfae221da
parentedb99a2b05865aca685c1401c90710428170c424 (diff)
downloadspack-1f3f1100b321356ca765cfda7d3f40b350653519.tar.gz
spack-1f3f1100b321356ca765cfda7d3f40b350653519.tar.bz2
spack-1f3f1100b321356ca765cfda7d3f40b350653519.tar.xz
spack-1f3f1100b321356ca765cfda7d3f40b350653519.zip
New packages: BigDFT suite (#26853)
-rw-r--r--var/spack/repos/builtin/packages/bigdft-atlab/package.py85
-rw-r--r--var/spack/repos/builtin/packages/bigdft-chess/package.py120
-rw-r--r--var/spack/repos/builtin/packages/bigdft-core/package.py134
-rw-r--r--var/spack/repos/builtin/packages/bigdft-futile/package.py100
-rw-r--r--var/spack/repos/builtin/packages/bigdft-libabinit/m_libpaw_mpi.F90.patch222
-rw-r--r--var/spack/repos/builtin/packages/bigdft-libabinit/package.py86
-rw-r--r--var/spack/repos/builtin/packages/bigdft-psolver/package.py113
-rw-r--r--var/spack/repos/builtin/packages/bigdft-spred/package.py107
-rw-r--r--var/spack/repos/builtin/packages/bigdft-suite/package.py39
-rw-r--r--var/spack/repos/builtin/packages/libgain/package.py25
-rw-r--r--var/spack/repos/builtin/packages/py-bigdft/package.py31
11 files changed, 1062 insertions, 0 deletions
diff --git a/var/spack/repos/builtin/packages/bigdft-atlab/package.py b/var/spack/repos/builtin/packages/bigdft-atlab/package.py
new file mode 100644
index 0000000000..5fc6f832b8
--- /dev/null
+++ b/var/spack/repos/builtin/packages/bigdft-atlab/package.py
@@ -0,0 +1,85 @@
+# Copyright 2013-2021 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)
+
+from spack import *
+
+
+class BigdftAtlab(AutotoolsPackage):
+ """BigDFT-atlab: library for ATomic related operations."""
+
+ homepage = "https://bigdft.org/"
+ url = "https://gitlab.com/l_sim/bigdft-suite/-/archive/1.9.2/bigdft-suite-1.9.2.tar.gz"
+ git = "https://gitlab.com/l_sim/bigdft-suite.git"
+
+ version('develop', branch='devel')
+ version('1.9.2', sha256='dc9e49b68f122a9886fa0ef09970f62e7ba21bb9ab1b86be9b7d7e22ed8fbe0f')
+ version('1.9.1', sha256='3c334da26d2a201b572579fc1a7f8caad1cbf971e848a3e10d83bc4dc8c82e41')
+ version('1.9.0', sha256='4500e505f5a29d213f678a91d00a10fef9dc00860ea4b3edf9280f33ed0d1ac8')
+ version('1.8.3', sha256='f112bb08833da4d11dd0f14f7ab10d740b62bc924806d77c985eb04ae0629909')
+
+ variant('mpi', default=True, description='Enable MPI support')
+ variant('openmp', default=True, description='Enable OpenMP support')
+ variant('openbabel', default=False, description='Enable detection of openbabel compilation')
+
+ depends_on('mpi', when='+mpi')
+ depends_on('openbabel', when='+openbabel')
+
+ for vers in ['1.8.1', '1.8.2', '1.8.3', '1.9.0', '1.9.1', '1.9.2', 'develop']:
+ depends_on('bigdft-futile@{0}'.format(vers), when='@{0}'.format(vers))
+
+ phases = ['autoreconf', 'configure', 'build', 'install']
+
+ build_directory = "atlab"
+
+ def autoreconf(self, spec, prefix):
+ autoreconf = which('autoreconf')
+
+ with working_dir(self.build_directory):
+ autoreconf('-fi')
+
+ def configure_args(self):
+ spec = self.spec
+ prefix = self.prefix
+
+ openmp_flag = []
+ if '+openmp' in spec:
+ openmp_flag.append(self.compiler.openmp_flag)
+
+ args = [
+ "FCFLAGS=%s" % " ".join(openmp_flag),
+ "--with-futile-libs=%s" % spec['bigdft-futile'].prefix.lib,
+ "--with-futile-incs=%s" % spec['bigdft-futile'].prefix.include,
+ "--with-moduledir=%s" % prefix.include,
+ "--prefix=%s" % prefix,
+ "--without-etsf-io",
+ ]
+
+ if '+mpi' in spec:
+ args.append("CC=%s" % spec['mpi'].mpicc)
+ args.append("CXX=%s" % spec['mpi'].mpicxx)
+ args.append("FC=%s" % spec['mpi'].mpifc)
+ args.append("F90=%s" % spec['mpi'].mpifc)
+ args.append("F77=%s" % spec['mpi'].mpif77)
+ else:
+ args.append("--disable-mpi")
+
+ if '+openmp' in spec:
+ args.append("--with-openmp")
+ else:
+ args.append("--without-openmp")
+
+ if '+openbabel' in spec:
+ args.append("--enable-openbabel")
+ args.append("--with-openbabel-libs=%s" % spec['openbabel'].prefix.lib)
+ args.append("--with-openbabel-incs=%s" % spec['openbabel'].prefix.include)
+
+ return args
+
+ @property
+ def libs(self):
+ shared = "+shared" in self.spec
+ return find_libraries(
+ 'libatlab-*', root=self.prefix, shared=shared, recursive=True
+ )
diff --git a/var/spack/repos/builtin/packages/bigdft-chess/package.py b/var/spack/repos/builtin/packages/bigdft-chess/package.py
new file mode 100644
index 0000000000..d975c822af
--- /dev/null
+++ b/var/spack/repos/builtin/packages/bigdft-chess/package.py
@@ -0,0 +1,120 @@
+# Copyright 2013-2021 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)
+
+from spack import *
+
+
+class BigdftChess(AutotoolsPackage, CudaPackage):
+ """BigDFT-CheSS: A module for performing Fermi Operator Expansions
+ via Chebyshev Polynomials."""
+
+ homepage = "https://bigdft.org/"
+ url = "https://gitlab.com/l_sim/bigdft-suite/-/archive/1.9.2/bigdft-suite-1.9.2.tar.gz"
+ git = "https://gitlab.com/l_sim/bigdft-suite.git"
+
+ version('develop', branch='devel')
+ version('1.9.2', sha256='dc9e49b68f122a9886fa0ef09970f62e7ba21bb9ab1b86be9b7d7e22ed8fbe0f')
+ version('1.9.1', sha256='3c334da26d2a201b572579fc1a7f8caad1cbf971e848a3e10d83bc4dc8c82e41')
+ version('1.9.0', sha256='4500e505f5a29d213f678a91d00a10fef9dc00860ea4b3edf9280f33ed0d1ac8')
+ version('1.8.3', sha256='f112bb08833da4d11dd0f14f7ab10d740b62bc924806d77c985eb04ae0629909')
+ version('1.8.2', sha256='042e5a3b478b1a4c050c450a9b1be7bcf8e13eacbce4759b7f2d79268b298d61')
+ version('1.8.1', sha256='e09ff0ba381f6ffbe6a3c0cb71db5b73117874beb41f22a982a7e5ba32d018b3')
+
+ variant('mpi', default=True, description='Enable MPI support')
+ variant('openmp', default=True, description='Enable OpenMP support')
+ variant('scalapack', default=True, description='Enable SCALAPACK support')
+ variant('ntpoly', default=False, description='Option to use NTPoly')
+ # variant('minpack', default=False, description='Give the link-line for MINPACK')
+
+ depends_on('python@:2.8', type=('build', 'run'), when="@:1.8.3")
+ depends_on('python@3.0:', type=('build', 'run'), when="@1.9.0:")
+ depends_on('python@3.0:', type=('build', 'run'), when="@develop")
+
+ depends_on('blas')
+ depends_on('lapack')
+ depends_on('py-pyyaml')
+ depends_on('mpi', when='+mpi')
+ depends_on('scalapack', when='+scalapack')
+ depends_on('ntpoly', when='+ntpoly')
+ # depends_on('netlib-minpack', when='+minpack')
+
+ for vers in ['1.8.1', '1.8.2', '1.8.3', '1.9.0', '1.9.1', '1.9.2', 'develop']:
+ depends_on('bigdft-futile@{0}'.format(vers), when='@{0}'.format(vers))
+ for vers in ['1.8.3', '1.9.0', '1.9.1', '1.9.2', 'develop']:
+ depends_on('bigdft-atlab@{0}'.format(vers), when='@{0}'.format(vers))
+
+ phases = ['autoreconf', 'configure', 'build', 'install']
+
+ build_directory = "chess"
+
+ def autoreconf(self, spec, prefix):
+ autoreconf = which('autoreconf')
+
+ with working_dir(self.build_directory):
+ autoreconf('-fi')
+
+ def configure_args(self):
+ spec = self.spec
+ prefix = self.prefix
+
+ python_version = spec['python'].version.up_to(2)
+ pyyaml = join_path(spec['py-pyyaml'].prefix.lib,
+ 'python{0}'.format(python_version))
+
+ openmp_flag = []
+ if '+openmp' in spec:
+ openmp_flag.append(self.compiler.openmp_flag)
+
+ linalg = []
+ if '+scalapack' in spec:
+ linalg.append(spec['scalapack'].libs.ld_flags)
+
+ args = [
+ "FCFLAGS=%s" % " ".join(openmp_flag),
+ "--with-ext-linalg=%s" % " ".join(linalg),
+ "--with-pyyaml-path=%s" % pyyaml,
+ "--with-futile-libs=%s" % spec['bigdft-futile'].prefix.lib,
+ "--with-futile-incs=%s" % spec['bigdft-futile'].headers.include_flags,
+ "--with-moduledir=%s" % prefix.include,
+ "--prefix=%s" % prefix,
+ "--without-etsf-io",
+ ]
+
+ if '+mpi' in spec:
+ args.append("CC=%s" % spec['mpi'].mpicc)
+ args.append("CXX=%s" % spec['mpi'].mpicxx)
+ args.append("FC=%s" % spec['mpi'].mpifc)
+ args.append("F90=%s" % spec['mpi'].mpifc)
+ args.append("F77=%s" % spec['mpi'].mpif77)
+ else:
+ args.append("--disable-mpi")
+
+ if '+openmp' in spec:
+ args.append("--with-openmp")
+ else:
+ args.append("--without-openmp")
+
+ if spec.satisfies('@1.8.3:') or spec.satisfies('@develop'):
+ args.append("--with-atlab-libs=%s" % spec['bigdft-atlab'].prefix.lib)
+
+ if '+cuda' in spec:
+ args.append("--enable-cuda-gpu")
+ args.append("--with-cuda-path=%s" % spec['cuda'].prefix)
+ args.append("--with-cuda-libs=%s" % spec['cuda'].libs.link_flags)
+
+ if '+minpack' in spec:
+ args.append("--with-minpack")
+
+ if '+ntpoly' in spec:
+ args.append("--enable-ntpoly")
+
+ return args
+
+ @property
+ def libs(self):
+ shared = "+shared" in self.spec
+ return find_libraries(
+ 'libCheSS-*', root=self.prefix, shared=shared, recursive=True
+ )
diff --git a/var/spack/repos/builtin/packages/bigdft-core/package.py b/var/spack/repos/builtin/packages/bigdft-core/package.py
new file mode 100644
index 0000000000..6d5df88413
--- /dev/null
+++ b/var/spack/repos/builtin/packages/bigdft-core/package.py
@@ -0,0 +1,134 @@
+# Copyright 2013-2021 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)
+
+from spack import *
+
+
+class BigdftCore(AutotoolsPackage, CudaPackage):
+ """BigDFT-core: the core components of BigDFT, an electronic structure calculation
+ based on Daubechies wavelets."""
+
+ homepage = "https://bigdft.org/"
+ url = "https://gitlab.com/l_sim/bigdft-suite/-/archive/1.9.2/bigdft-suite-1.9.2.tar.gz"
+ git = "https://gitlab.com/l_sim/bigdft-suite.git"
+
+ version('develop', branch='devel')
+ version('1.9.2', sha256='dc9e49b68f122a9886fa0ef09970f62e7ba21bb9ab1b86be9b7d7e22ed8fbe0f')
+ version('1.9.1', sha256='3c334da26d2a201b572579fc1a7f8caad1cbf971e848a3e10d83bc4dc8c82e41')
+ version('1.9.0', sha256='4500e505f5a29d213f678a91d00a10fef9dc00860ea4b3edf9280f33ed0d1ac8')
+ version('1.8.3', sha256='f112bb08833da4d11dd0f14f7ab10d740b62bc924806d77c985eb04ae0629909')
+ version('1.8.2', sha256='042e5a3b478b1a4c050c450a9b1be7bcf8e13eacbce4759b7f2d79268b298d61')
+ version('1.8.1', sha256='e09ff0ba381f6ffbe6a3c0cb71db5b73117874beb41f22a982a7e5ba32d018b3')
+
+ variant('mpi', default=True, description='Enable MPI support')
+ variant('openmp', default=True, description='Enable OpenMP support')
+ variant('scalapack', default=True, description='Enable SCALAPACK support')
+ variant('openbabel', default=False, description='Enable detection of openbabel compilation')
+
+ depends_on('python@:2.8', type=('build', 'run'), when="@:1.8.3")
+ depends_on('python@3.0:', type=('build', 'run'), when="@1.9.0:")
+ depends_on('python@3.0:', type=('build', 'run'), when="@develop")
+
+ depends_on('blas')
+ depends_on('lapack')
+ depends_on('py-pyyaml')
+ depends_on('libgain')
+ depends_on('mpi', when='+mpi')
+ depends_on('scalapack', when='+scalapack')
+ depends_on('openbabel', when='+openbabel')
+ depends_on('libxc@:2.2.2', when='@:1.9.1')
+ depends_on('libxc@:4.3.4', when='@1.9.2:')
+ depends_on('libxc@:4.3.4', when='@develop')
+
+ for vers in ['1.8.1', '1.8.2', '1.8.3', '1.9.0', '1.9.1', '1.9.2', 'develop']:
+ depends_on('bigdft-futile@{0}'.format(vers), when='@{0}'.format(vers))
+ depends_on('bigdft-chess@{0}'.format(vers), when='@{0}'.format(vers))
+ depends_on('bigdft-psolver@{0}'.format(vers), when='@{0}'.format(vers))
+ depends_on('bigdft-libabinit@{0}'.format(vers), when='@{0}'.format(vers))
+
+ phases = ['autoreconf', 'configure', 'build', 'install']
+
+ build_directory = "bigdft"
+
+ def autoreconf(self, spec, prefix):
+ autoreconf = which('autoreconf')
+
+ with working_dir(self.build_directory):
+ autoreconf('-fi')
+
+ def configure_args(self):
+ spec = self.spec
+ prefix = self.prefix
+
+ python_version = spec['python'].version.up_to(2)
+ pyyaml = join_path(spec['py-pyyaml'].prefix.lib,
+ 'python{0}'.format(python_version))
+
+ openmp_flag = []
+ if '+openmp' in spec:
+ openmp_flag.append(self.compiler.openmp_flag)
+
+ linalg = []
+ if '+scalapack' in spec:
+ linalg.append(spec['scalapack'].libs.ld_flags)
+ linalg.append(spec['lapack'].libs.ld_flags)
+ linalg.append(spec['blas'].libs.ld_flags)
+
+ args = [
+ "FCFLAGS=%s" % " ".join(openmp_flag),
+ "--with-ext-linalg=%s" % " ".join(linalg),
+ "--with-pyyaml-path=%s" % pyyaml,
+ "--with-futile-libs=%s" % spec['bigdft-futile'].prefix.lib,
+ "--with-futile-incs=%s" % spec['bigdft-futile'].headers.include_flags,
+ "--with-chess-libs=%s" % spec['bigdft-chess'].prefix.lib,
+ "--with-chess-incs=%s" % spec['bigdft-chess'].headers.include_flags,
+ "--with-psolver-libs=%s" % spec['bigdft-psolver'].prefix.lib,
+ "--with-psolver-incs=%s" % spec['bigdft-psolver'].headers.include_flags,
+ "--with-libABINIT-libs=%s" % spec['bigdft-libabinit'].prefix.lib,
+ "--with-libABINIT-incs=%s" % spec['bigdft-libabinit'].headers.include_flags,
+ "--with-libgain-libs=%s" % spec['libgain'].libs.ld_flags,
+ "--with-libgain-incs=%s" % spec['libgain'].headers.include_flags,
+ "--with-libxc-libs=%s %s" % (spec['libxc'].libs.ld_flags,
+ spec['libxc'].libs.ld_flags + "f90"),
+ "--with-libxc-incs=%s" % spec['libxc'].headers.include_flags,
+ "--with-moduledir=%s" % prefix.include,
+ "--prefix=%s" % prefix,
+ "--without-etsf-io",
+ ]
+
+ if '+mpi' in spec:
+ args.append("CC=%s" % spec['mpi'].mpicc)
+ args.append("CXX=%s" % spec['mpi'].mpicxx)
+ args.append("FC=%s" % spec['mpi'].mpifc)
+ args.append("F90=%s" % spec['mpi'].mpifc)
+ args.append("F77=%s" % spec['mpi'].mpif77)
+ else:
+ args.append("--disable-mpi")
+
+ if '+openmp' in spec:
+ args.append("--with-openmp")
+ else:
+ args.append("--without-openmp")
+
+ if '+cuda' in spec:
+ args.append("--enable-opencl")
+ args.append("--with-ocl-path=%s" % spec['cuda'].prefix)
+ args.append("--enable-cuda-gpu")
+ args.append("--with-cuda-path=%s" % spec['cuda'].prefix)
+ args.append("--with-cuda-libs=%s" % spec['cuda'].libs.link_flags)
+
+ if '+openbabel' in spec:
+ args.append("--enable-openbabel")
+ args.append("--with-openbabel-libs=%s" % spec['openbabel'].prefix.lib)
+ args.append("--with-openbabel-incs=%s" % spec['openbabel'].prefix.include)
+
+ return args
+
+ @property
+ def libs(self):
+ shared = "+shared" in self.spec
+ return find_libraries(
+ 'libbigdft-*', root=self.prefix, shared=shared, recursive=True
+ )
diff --git a/var/spack/repos/builtin/packages/bigdft-futile/package.py b/var/spack/repos/builtin/packages/bigdft-futile/package.py
new file mode 100644
index 0000000000..936b9f301a
--- /dev/null
+++ b/var/spack/repos/builtin/packages/bigdft-futile/package.py
@@ -0,0 +1,100 @@
+# Copyright 2013-2021 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)
+
+from spack import *
+
+
+class BigdftFutile(AutotoolsPackage, CudaPackage):
+ """BigDFT-futile: a library handling most common FORTRAN low-level operations,
+ like memory managment, profiling routines, I/O operations.
+ It also supports yaml output and parsing for fortran programs.
+ It also provides wrappers routines to MPI and linear algebra operations.
+ This library is intensively used in BigDFT packages."""
+
+ homepage = "https://bigdft.org/"
+ url = "https://gitlab.com/l_sim/bigdft-suite/-/archive/1.9.2/bigdft-suite-1.9.2.tar.gz"
+ git = "https://gitlab.com/l_sim/bigdft-suite.git"
+
+ version('develop', branch='devel')
+ version('1.9.2', sha256='dc9e49b68f122a9886fa0ef09970f62e7ba21bb9ab1b86be9b7d7e22ed8fbe0f')
+ version('1.9.1', sha256='3c334da26d2a201b572579fc1a7f8caad1cbf971e848a3e10d83bc4dc8c82e41')
+ version('1.9.0', sha256='4500e505f5a29d213f678a91d00a10fef9dc00860ea4b3edf9280f33ed0d1ac8')
+ version('1.8.3', sha256='f112bb08833da4d11dd0f14f7ab10d740b62bc924806d77c985eb04ae0629909')
+ version('1.8.2', sha256='042e5a3b478b1a4c050c450a9b1be7bcf8e13eacbce4759b7f2d79268b298d61')
+ version('1.8.1', sha256='e09ff0ba381f6ffbe6a3c0cb71db5b73117874beb41f22a982a7e5ba32d018b3')
+
+ variant('mpi', default=True, description='Enable MPI support')
+ variant('openmp', default=True, description='Enable OpenMP support')
+
+ depends_on('python@:2.8', type=('build', 'run'), when="@:1.8.3")
+ depends_on('python@3.0:', type=('build', 'run'), when="@1.9.0:")
+ depends_on('python@3.0:', type=('build', 'run'), when="@develop")
+
+ depends_on('blas')
+ depends_on('lapack')
+ depends_on('libyaml')
+ depends_on('py-pyyaml')
+ depends_on('mpi', when='+mpi')
+
+ phases = ['autoreconf', 'configure', 'build', 'install']
+
+ build_directory = "futile"
+
+ def autoreconf(self, spec, prefix):
+ autoreconf = which('autoreconf')
+
+ with working_dir(self.build_directory):
+ autoreconf('-fi')
+
+ def configure_args(self):
+ spec = self.spec
+ prefix = self.prefix
+
+ linalg = [spec['blas'].libs.ld_flags, spec['lapack'].libs.ld_flags]
+
+ python_version = spec['python'].version.up_to(2)
+ pyyaml = join_path(spec['py-pyyaml'].prefix.lib,
+ 'python{0}'.format(python_version))
+
+ openmp_flag = []
+ if '+openmp' in spec:
+ openmp_flag.append(self.compiler.openmp_flag)
+
+ args = [
+ "FCFLAGS=%s" % " ".join(openmp_flag),
+ "--with-ext-linalg=%s" % " ".join(linalg),
+ "--with-yaml-path=%s" % spec['libyaml'].prefix,
+ "--with-pyyaml-path=%s" % pyyaml,
+ "--prefix=%s" % prefix,
+ ]
+
+ if '+openmp' in spec:
+ args.append("--with-openmp")
+ else:
+ args.append("--without-openmp")
+
+ if '+mpi' in spec:
+ args.append("CC=%s" % spec['mpi'].mpicc)
+ args.append("CXX=%s" % spec['mpi'].mpicxx)
+ args.append("FC=%s" % spec['mpi'].mpifc)
+ args.append("F90=%s" % spec['mpi'].mpifc)
+ args.append("F77=%s" % spec['mpi'].mpif77)
+ else:
+ args.append("--disable-mpi")
+
+ if '+cuda' in spec:
+ args.append("--enable-opencl")
+ args.append("--with-ocl-path=%s" % spec['cuda'].prefix)
+ args.append("--enable-cuda-gpu")
+ args.append("--with-cuda-path=%s" % spec['cuda'].prefix)
+
+ return args
+
+ @property
+ def libs(self):
+ shared = "+shared" in self.spec
+ return find_libraries(
+ 'libfutile-*', root=self.prefix, shared=shared, recursive=True
+ )
diff --git a/var/spack/repos/builtin/packages/bigdft-libabinit/m_libpaw_mpi.F90.patch b/var/spack/repos/builtin/packages/bigdft-libabinit/m_libpaw_mpi.F90.patch
new file mode 100644
index 0000000000..4ee3c1df31
--- /dev/null
+++ b/var/spack/repos/builtin/packages/bigdft-libabinit/m_libpaw_mpi.F90.patch
@@ -0,0 +1,222 @@
+--- a/libABINIT/src/libpaw/m_libpaw_mpi.F90
++++ b/libABINIT/src/libpaw/m_libpaw_mpi.F90
+@@ -54,6 +54,24 @@
+ integer,public,parameter :: xpaw_mpi_comm_null = 0
+ #endif
+
++ type xpaw_mpi_attr
++ integer :: attr_data
++ end type
++
++ interface xpaw_mpi_attr
++ module procedure new_xpaw_mpi_attr
++ end interface
++
++ interface mod
++ module procedure mod_xpaw_mpi_attr
++ end interface
++
++#ifdef HAVE_MPI
++ type(xpaw_mpi_attr),public,parameter :: xpaw_mpi_tag_ub = xpaw_mpi_attr(MPI_TAG_UB)
++#else
++ integer,public,parameter :: xpaw_mpi_tag_ub = 1
++#endif
++
+ !----------------------------------------------------------------------
+ !MPI public procedures.
+
+@@ -180,6 +198,32 @@
+ CONTAINS !===========================================================
+ !!***
+
++function new_xpaw_mpi_attr(key_val)
++ type(xpaw_mpi_attr) :: new_xpaw_mpi_attr
++ integer, intent(in) :: key_val
++!Local variables-------------------
++ integer :: mpierr
++#ifdef HAVE_MPI
++ integer :: attribute_val
++ logical :: lflag
++#endif
++
++ ! Deprecated in MPI2 but not all MPI2 implementations provide MPI_Comm_get_attr !
++ call MPI_ATTR_GET(xpaw_mpi_world, key_val, attribute_val, lflag, mpierr)
++ !call MPI_Comm_get_attr(xpaw_mpi_world, key_val, attribute_val, lflag, mpierr)
++
++ if (lflag) new_xpaw_mpi_attr%attr_data = attribute_val
++end function
++
++
++function mod_xpaw_mpi_attr(a, p)
++ integer :: mod_xpaw_mpi_attr
++ integer, intent(in) :: a
++ type(xpaw_mpi_attr), intent(in) :: p
++
++ mod_xpaw_mpi_attr = mod(a, p%attr_data)
++end function
++
+ !!****f* m_libpaw_mpi/xpaw_mpi_abort
+ !! NAME
+ !! xpaw_mpi_abort
+@@ -2297,7 +2341,7 @@
+ #if defined HAVE_MPI
+ if (spaceComm /= xpaw_mpi_comm_self .and. spaceComm /= xpaw_mpi_comm_null) then
+ n1=size(xval,dim=1)
+- my_tag = MOD(tag,MPI_TAG_UB)
++ my_tag = MOD(tag,xpaw_mpi_tag_ub)
+ call MPI_RECV(xval,n1,MPI_INTEGER,source,my_tag,spaceComm,MPI_STATUS_IGNORE,ier)
+ end if
+ #endif
+@@ -2358,7 +2402,7 @@
+ #if defined HAVE_MPI
+ if (spaceComm /= xpaw_mpi_comm_self .and. spaceComm /= xpaw_mpi_comm_null) then
+ n1=size(xval,dim=1)
+- my_tag = MOD(tag,MPI_TAG_UB)
++ my_tag = MOD(tag,xpaw_mpi_tag_ub)
+ call MPI_RECV(xval,n1,MPI_DOUBLE_PRECISION,source,my_tag,spaceComm,MPI_STATUS_IGNORE,ier)
+ end if
+ #endif
+@@ -2419,7 +2463,7 @@
+ #if defined HAVE_MPI
+ if (spaceComm /= xpaw_mpi_comm_self .and. spaceComm /= xpaw_mpi_comm_null) then
+ n1=size(xval,dim=1) ; n2=size(xval,dim=2)
+- my_tag=MOD(tag,MPI_TAG_UB)
++ my_tag=MOD(tag,xpaw_mpi_tag_ub)
+ call MPI_RECV(xval,n1*n2,MPI_DOUBLE_PRECISION,source,my_tag,spaceComm,MPI_STATUS_IGNORE,ier)
+ end if
+ #endif
+@@ -2480,7 +2524,7 @@
+ #if defined HAVE_MPI
+ if (spaceComm /= xpaw_mpi_comm_self .and. spaceComm /= xpaw_mpi_comm_null) then
+ n1=size(xval,dim=1) ; n2=size(xval,dim=2) ; n3=size(xval,dim=3)
+- my_tag=MOD(tag,MPI_TAG_UB)
++ my_tag=MOD(tag,xpaw_mpi_tag_ub)
+ call MPI_RECV(xval,n1*n2*n3,MPI_DOUBLE_PRECISION,source,my_tag,spaceComm,MPI_STATUS_IGNORE,ier)
+ end if
+ #endif
+@@ -2541,7 +2585,7 @@
+ ierr=0
+ #if defined HAVE_MPI
+ if (spaceComm /= xpaw_mpi_comm_self .and. spaceComm /= xpaw_mpi_comm_null) then
+- my_tag=MOD(tag,MPI_TAG_UB)
++ my_tag=MOD(tag,xpaw_mpi_tag_ub)
+ n1=size(xval)
+ call MPI_IRECV(xval,n1,MPI_INTEGER,source,my_tag,spaceComm,request,ier)
+ ierr=ier
+@@ -2604,7 +2648,7 @@
+ #if defined HAVE_MPI
+ if (spaceComm /= xpaw_mpi_comm_self .and. spaceComm /= xpaw_mpi_comm_null) then
+ n1=size(xval,dim=1)
+- my_tag=MOD(tag,MPI_TAG_UB)
++ my_tag=MOD(tag,xpaw_mpi_tag_ub)
+ call MPI_IRECV(xval,n1,MPI_DOUBLE_PRECISION,source,my_tag,spaceComm,request,ier)
+ ierr=ier
+ end if
+@@ -2666,7 +2710,7 @@
+ #if defined HAVE_MPI
+ if (spaceComm /= xpaw_mpi_comm_self .and. spaceComm /= xpaw_mpi_comm_null) then
+ n1=size(xval,dim=1);n2=size(xval,dim=2)
+- my_tag=MOD(tag,MPI_TAG_UB)
++ my_tag=MOD(tag,xpaw_mpi_tag_ub)
+ call MPI_IRECV(xval,n1*n2,MPI_DOUBLE_PRECISION,source,my_tag,spaceComm,request,ier)
+ ierr=ier
+ end if
+@@ -2727,7 +2771,7 @@
+ #if defined HAVE_MPI
+ if (spaceComm /= xpaw_mpi_comm_self .and. spaceComm /= xpaw_mpi_comm_null) then
+ n1=size(xval,dim=1)
+- my_tag = MOD(tag,MPI_TAG_UB)
++ my_tag = MOD(tag,xpaw_mpi_tag_ub)
+ call MPI_SEND(xval,n1,MPI_INTEGER,dest,my_tag,spaceComm,ier)
+ end if
+ #endif
+@@ -2785,7 +2829,7 @@
+ #if defined HAVE_MPI
+ if (spaceComm /= xpaw_mpi_comm_self .and. spaceComm /= xpaw_mpi_comm_null) then
+ n1=size(xval,dim=1)
+- my_tag = MOD(tag,MPI_TAG_UB)
++ my_tag = MOD(tag,xpaw_mpi_tag_ub)
+ call MPI_SEND(xval,n1,MPI_DOUBLE_PRECISION,dest,my_tag,spaceComm,ier)
+ end if
+ #endif
+@@ -2843,7 +2887,7 @@
+ #if defined HAVE_MPI
+ if (spaceComm /= xpaw_mpi_comm_self .and. spaceComm /= xpaw_mpi_comm_null) then
+ n1=size(xval,dim=1) ; n2=size(xval,dim=2)
+- my_tag = MOD(tag,MPI_TAG_UB)
++ my_tag = MOD(tag,xpaw_mpi_tag_ub)
+ call MPI_SEND(xval,n1*n2,MPI_DOUBLE_PRECISION,dest,my_tag,spaceComm,ier)
+ end if
+ #endif
+@@ -2901,7 +2945,7 @@
+ #if defined HAVE_MPI
+ if (spaceComm /= xpaw_mpi_comm_self .and. spaceComm /= xpaw_mpi_comm_null) then
+ n1=size(xval,dim=1) ; n2=size(xval,dim=2) ; n3=size(xval,dim=3)
+- my_tag = MOD(tag,MPI_TAG_UB)
++ my_tag = MOD(tag,xpaw_mpi_tag_ub)
+ call MPI_SEND(xval,n1*n2*n3,MPI_DOUBLE_PRECISION,dest,my_tag,spaceComm,ier)
+ end if
+ #endif
+@@ -2961,7 +3005,7 @@
+ #if defined HAVE_MPI
+ if (spaceComm /= xpaw_mpi_comm_self .and. spaceComm /= xpaw_mpi_comm_null) then
+ n1=size(xval,dim=1)
+- my_tag = MOD(tag,MPI_TAG_UB)
++ my_tag = MOD(tag,xpaw_mpi_tag_ub)
+ call MPI_ISEND(xval,n1,MPI_INTEGER,dest,my_tag,spaceComm,request,ier)
+ ierr=ier
+ end if
+@@ -3020,7 +3064,7 @@
+ #if defined HAVE_MPI
+ if (spaceComm /= xpaw_mpi_comm_self .and. spaceComm /= xpaw_mpi_comm_null) then
+ n1=size(xval,dim=1)
+- my_tag = MOD(tag,MPI_TAG_UB)
++ my_tag = MOD(tag,xpaw_mpi_tag_ub)
+ call MPI_ISEND(xval,n1,MPI_DOUBLE_PRECISION,dest,my_tag,spaceComm,request,ier)
+ ierr=ier
+ end if
+@@ -3079,7 +3123,7 @@
+ #if defined HAVE_MPI
+ if (spaceComm /= xpaw_mpi_comm_self .and. spaceComm /= xpaw_mpi_comm_null) then
+ n1=size(xval,dim=1) ; n1=size(xval,dim=2)
+- my_tag = MOD(tag,MPI_TAG_UB)
++ my_tag = MOD(tag,xpaw_mpi_tag_ub)
+ call MPI_ISEND(xval,n1*n2,MPI_DOUBLE_PRECISION,dest,my_tag,spaceComm,request,ier)
+ ierr=ier
+ end if
+@@ -3145,7 +3189,7 @@
+ #if defined HAVE_MPI
+ if (sender==recever.or.spaceComm==xpaw_mpi_comm_null.or.(n1==0)) return
+ call MPI_COMM_RANK(spaceComm,me,ier)
+- tag = MOD(n1,MPI_TAG_UB)
++ tag = MOD(n1,xpaw_mpi_tag_ub)
+ if (recever==me) then
+ call MPI_RECV(vrecv,n1,MPI_INTEGER,sender,tag,spaceComm,status,ier)
+ end if
+@@ -3212,7 +3256,7 @@
+ #if defined HAVE_MPI
+ if (sender==recever.or.spaceComm==xpaw_mpi_comm_null.or.(n1==0)) return
+ call MPI_COMM_RANK(spaceComm,me,ier)
+- tag = MOD(n1,MPI_TAG_UB)
++ tag = MOD(n1,xpaw_mpi_tag_ub)
+ if (recever==me) then
+ call MPI_RECV(vrecv,n1,MPI_DOUBLE_PRECISION,sender,tag,spaceComm,status,ier)
+ end if
+@@ -3279,7 +3323,7 @@
+ #if defined HAVE_MPI
+ if (sender==recever.or.spaceComm==xpaw_mpi_comm_null.or.(nt==0)) return
+ call MPI_COMM_RANK(spaceComm,me,ier)
+- tag=MOD(nt,MPI_TAG_UB)
++ tag=MOD(nt,xpaw_mpi_tag_ub)
+ if (recever==me) then
+ call MPI_RECV(vrecv,nt,MPI_DOUBLE_PRECISION,sender,tag,spaceComm,status,ier)
+ end if
+@@ -3346,7 +3390,7 @@
+ #if defined HAVE_MPI
+ if (sender==recever.or.spaceComm==xpaw_mpi_comm_null.or.(nt==0)) return
+ call MPI_COMM_RANK(spaceComm,me,ier)
+- tag=MOD(nt,MPI_TAG_UB)
++ tag=MOD(nt,xpaw_mpi_tag_ub)
+ if (recever==me) then
+ call MPI_RECV(vrecv,nt,MPI_DOUBLE_PRECISION,sender,tag,spaceComm,status,ier)
+ end if
diff --git a/var/spack/repos/builtin/packages/bigdft-libabinit/package.py b/var/spack/repos/builtin/packages/bigdft-libabinit/package.py
new file mode 100644
index 0000000000..ff61338334
--- /dev/null
+++ b/var/spack/repos/builtin/packages/bigdft-libabinit/package.py
@@ -0,0 +1,86 @@
+# Copyright 2013-2021 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)
+
+from spack import *
+
+
+class BigdftLibabinit(AutotoolsPackage):
+ """BigDFT-libABINIT: this is a subsection of files coming from ABINIT software package,
+ to which BigDFT has been coupled since the early days. It handles different parts
+ like symmetries, ewald corrections, PAW routines, density and potential mixing
+ routines and some MD minimizers."""
+
+ homepage = "https://bigdft.org/"
+ url = "https://gitlab.com/l_sim/bigdft-suite/-/archive/1.9.2/bigdft-suite-1.9.2.tar.gz"
+ git = "https://gitlab.com/l_sim/bigdft-suite.git"
+
+ version('develop', branch='devel')
+ version('1.9.2', sha256='dc9e49b68f122a9886fa0ef09970f62e7ba21bb9ab1b86be9b7d7e22ed8fbe0f')
+ version('1.9.1', sha256='3c334da26d2a201b572579fc1a7f8caad1cbf971e848a3e10d83bc4dc8c82e41')
+ version('1.9.0', sha256='4500e505f5a29d213f678a91d00a10fef9dc00860ea4b3edf9280f33ed0d1ac8')
+ version('1.8.3', sha256='f112bb08833da4d11dd0f14f7ab10d740b62bc924806d77c985eb04ae0629909')
+ version('1.8.2', sha256='042e5a3b478b1a4c050c450a9b1be7bcf8e13eacbce4759b7f2d79268b298d61')
+ version('1.8.1', sha256='e09ff0ba381f6ffbe6a3c0cb71db5b73117874beb41f22a982a7e5ba32d018b3')
+
+ variant('mpi', default=True, description='Enable MPI support')
+
+ depends_on('python@:2.8', type=('build', 'run'), when="@:1.8.3")
+ depends_on('python@3.0:', type=('build', 'run'), when="@1.9.0:")
+ depends_on('python@3.0:', type=('build', 'run'), when="@develop")
+
+ depends_on('mpi', when='+mpi')
+ depends_on('libxc@:2.2.2', when='@:1.9.1')
+ depends_on('libxc@:4.3.4', when='@1.9.1:')
+ depends_on('libxc@:4.3.4', when='@develop')
+
+ for vers in ['1.8.1', '1.8.2', '1.8.3', '1.9.0', '1.9.1', '1.9.2', 'develop']:
+ depends_on('bigdft-futile@{0}'.format(vers), when='@{0}'.format(vers))
+
+ patch('m_libpaw_mpi.F90.patch', when='@:1.8.2')
+
+ phases = ['autoreconf', 'configure', 'build', 'install']
+
+ build_directory = "libABINIT"
+
+ def autoreconf(self, spec, prefix):
+ autoreconf = which('autoreconf')
+
+ with working_dir(self.build_directory):
+ if spec.satisfies('@:1.8.2'):
+ autoreconf('-i')
+ else:
+ autoreconf('-fi')
+
+ def configure_args(self):
+ spec = self.spec
+ prefix = self.prefix
+
+ args = [
+ "--with-libxc-libs=%s %s" % (spec['libxc'].libs.ld_flags,
+ spec['libxc'].libs.ld_flags + "f90"),
+ "--with-libxc-incs=%s" % spec['libxc'].headers.include_flags,
+ "--with-futile-libs=%s" % spec['bigdft-futile'].prefix.lib,
+ "--with-futile-incs=%s" % spec['bigdft-futile'].headers.include_flags,
+ "--with-moduledir=%s" % prefix.include,
+ "--prefix=%s" % prefix,
+ ]
+
+ if '+mpi' in spec:
+ args.append("CC=%s" % spec['mpi'].mpicc)
+ args.append("CXX=%s" % spec['mpi'].mpicxx)
+ args.append("FC=%s" % spec['mpi'].mpifc)
+ args.append("F90=%s" % spec['mpi'].mpifc)
+ args.append("F77=%s" % spec['mpi'].mpif77)
+ else:
+ args.append("--disable-mpi")
+
+ return args
+
+ @property
+ def libs(self):
+ shared = "+shared" in self.spec
+ return find_libraries(
+ 'libabinit', root=self.prefix, shared=shared, recursive=True
+ )
diff --git a/var/spack/repos/builtin/packages/bigdft-psolver/package.py b/var/spack/repos/builtin/packages/bigdft-psolver/package.py
new file mode 100644
index 0000000000..1ae24f617b
--- /dev/null
+++ b/var/spack/repos/builtin/packages/bigdft-psolver/package.py
@@ -0,0 +1,113 @@
+# Copyright 2013-2021 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)
+
+from spack import *
+
+
+class BigdftPsolver(AutotoolsPackage, CudaPackage):
+ """BigDFT-Psolver: a flexible real-space Poisson Solver based on
+ Interpolating Scaling Functions. It constitutes a fundamental building block
+ of BigDFT code, and it can also be used separately and linked to other codes."""
+
+ homepage = "https://bigdft.org/"
+ url = "https://gitlab.com/l_sim/bigdft-suite/-/archive/1.9.2/bigdft-suite-1.9.2.tar.gz"
+ git = "https://gitlab.com/l_sim/bigdft-suite.git"
+
+ version('develop', branch='devel')
+ version('1.9.2', sha256='dc9e49b68f122a9886fa0ef09970f62e7ba21bb9ab1b86be9b7d7e22ed8fbe0f')
+ version('1.9.1', sha256='3c334da26d2a201b572579fc1a7f8caad1cbf971e848a3e10d83bc4dc8c82e41')
+ version('1.9.0', sha256='4500e505f5a29d213f678a91d00a10fef9dc00860ea4b3edf9280f33ed0d1ac8')
+ version('1.8.3', sha256='f112bb08833da4d11dd0f14f7ab10d740b62bc924806d77c985eb04ae0629909')
+ version('1.8.2', sha256='042e5a3b478b1a4c050c450a9b1be7bcf8e13eacbce4759b7f2d79268b298d61')
+ version('1.8.1', sha256='e09ff0ba381f6ffbe6a3c0cb71db5b73117874beb41f22a982a7e5ba32d018b3')
+
+ variant('mpi', default=True, description='Enable MPI support')
+ variant('openmp', default=True, description='Enable OpenMP support')
+ variant('scalapack', default=True, description='Enable SCALAPACK support')
+
+ depends_on('python@:2.8', type=('build', 'run'), when="@:1.8.3")
+ depends_on('python@3.0:', type=('build', 'run'), when="@1.9.0:")
+ depends_on('python@3.0:', type=('build', 'run'), when="@develop")
+
+ depends_on('blas')
+ depends_on('lapack')
+ depends_on('py-pyyaml')
+ depends_on('mpi', when='+mpi')
+ depends_on('scalapack', when='+scalapack')
+
+ for vers in ['1.8.1', '1.8.2', '1.8.3', '1.9.0', '1.9.1', '1.9.2', 'develop']:
+ depends_on('bigdft-futile@{0}'.format(vers), when='@{0}'.format(vers))
+ for vers in ['1.8.3', '1.9.0', '1.9.1', '1.9.2', 'develop']:
+ depends_on('bigdft-atlab@{0}'.format(vers), when='@{0}'.format(vers))
+
+ phases = ['autoreconf', 'configure', 'build', 'install']
+
+ build_directory = "psolver"
+
+ def autoreconf(self, spec, prefix):
+ autoreconf = which('autoreconf')
+
+ with working_dir(self.build_directory):
+ autoreconf('-fi')
+
+ def configure_args(self):
+ spec = self.spec
+ prefix = self.prefix
+
+ python_version = spec['python'].version.up_to(2)
+ pyyaml = join_path(spec['py-pyyaml'].prefix.lib,
+ 'python{0}'.format(python_version))
+
+ openmp_flag = []
+ if '+openmp' in spec:
+ openmp_flag.append(self.compiler.openmp_flag)
+
+ linalg = []
+ if '+scalapack' in spec:
+ linalg.append(spec['scalapack'].libs.ld_flags)
+ linalg.append(spec['lapack'].libs.ld_flags)
+ linalg.append(spec['blas'].libs.ld_flags)
+
+ args = [
+ "FCFLAGS=%s" % " ".join(openmp_flag),
+ "--with-ext-linalg=%s" % " ".join(linalg),
+ "--with-pyyaml-path=%s" % pyyaml,
+ "--with-futile-libs=%s" % spec['bigdft-futile'].prefix.lib,
+ "--with-futile-incs=%s" % spec['bigdft-futile'].headers.include_flags,
+ "--with-moduledir=%s" % prefix.include,
+ "--prefix=%s" % prefix,
+ "--without-etsf-io",
+ ]
+
+ if '+mpi' in spec:
+ args.append("CC=%s" % spec['mpi'].mpicc)
+ args.append("CXX=%s" % spec['mpi'].mpicxx)
+ args.append("FC=%s" % spec['mpi'].mpifc)
+ args.append("F90=%s" % spec['mpi'].mpifc)
+ args.append("F77=%s" % spec['mpi'].mpif77)
+ else:
+ args.append("--disable-mpi")
+
+ if '+openmp' in spec:
+ args.append("--with-openmp")
+ else:
+ args.append("--without-openmp")
+
+ if spec.satisfies('@1.8.3:') or spec.satisfies('@develop'):
+ args.append("--with-atlab-libs=%s" % spec['bigdft-atlab'].prefix.lib)
+
+ if '+cuda' in spec:
+ args.append("--enable-cuda-gpu")
+ args.append("--with-cuda-path=%s" % spec['cuda'].prefix)
+ args.append("--with-cuda-libs=%s" % spec['cuda'].libs.link_flags)
+
+ return args
+
+ @property
+ def libs(self):
+ shared = "+shared" in self.spec
+ return find_libraries(
+ 'libPSolver-*', root=self.prefix, shared=shared, recursive=True
+ )
diff --git a/var/spack/repos/builtin/packages/bigdft-spred/package.py b/var/spack/repos/builtin/packages/bigdft-spred/package.py
new file mode 100644
index 0000000000..10a4cbac9c
--- /dev/null
+++ b/var/spack/repos/builtin/packages/bigdft-spred/package.py
@@ -0,0 +1,107 @@
+# Copyright 2013-2021 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)
+
+from spack import *
+
+
+class BigdftSpred(AutotoolsPackage):
+ """BigDFT-spred: a library for structure prediction tools,
+ that is compiled on top of BigDFT routines."""
+
+ homepage = "https://bigdft.org/"
+ url = "https://gitlab.com/l_sim/bigdft-suite/-/archive/1.9.2/bigdft-suite-1.9.2.tar.gz"
+ git = "https://gitlab.com/l_sim/bigdft-suite.git"
+
+ version('develop', branch='devel')
+ version('1.9.2', sha256='dc9e49b68f122a9886fa0ef09970f62e7ba21bb9ab1b86be9b7d7e22ed8fbe0f')
+ version('1.9.1', sha256='3c334da26d2a201b572579fc1a7f8caad1cbf971e848a3e10d83bc4dc8c82e41')
+ version('1.9.0', sha256='4500e505f5a29d213f678a91d00a10fef9dc00860ea4b3edf9280f33ed0d1ac8')
+ version('1.8.3', sha256='f112bb08833da4d11dd0f14f7ab10d740b62bc924806d77c985eb04ae0629909')
+ version('1.8.2', sha256='042e5a3b478b1a4c050c450a9b1be7bcf8e13eacbce4759b7f2d79268b298d61')
+ version('1.8.1', sha256='e09ff0ba381f6ffbe6a3c0cb71db5b73117874beb41f22a982a7e5ba32d018b3')
+
+ variant('mpi', default=True, description='Enable MPI support')
+ variant('openmp', default=True, description='Enable OpenMP support')
+ variant('scalapack', default=True, description='Enable SCALAPACK support')
+
+ depends_on('python@:2.8', type=('build', 'run'), when="@:1.8.3")
+ depends_on('python@3.0:', type=('build', 'run'), when="@1.9.0:")
+ depends_on('python@3.0:', type=('build', 'run'), when="@develop")
+
+ depends_on('blas')
+ depends_on('lapack')
+ depends_on('py-pyyaml')
+ depends_on('mpi', when='+mpi')
+ depends_on('scalapack', when='+scalapack')
+
+ for vers in ['1.8.1', '1.8.2', '1.8.3', '1.9.0', '1.9.1', '1.9.2', 'develop']:
+ depends_on('bigdft-futile@{0}'.format(vers), when='@{0}'.format(vers))
+ depends_on('bigdft-psolver@{0}'.format(vers), when='@{0}'.format(vers))
+ depends_on('bigdft-core@{0}'.format(vers), when='@{0}'.format(vers))
+
+ phases = ['autoreconf', 'configure', 'build', 'install']
+
+ build_directory = "spred"
+
+ def autoreconf(self, spec, prefix):
+ autoreconf = which('autoreconf')
+
+ with working_dir(self.build_directory):
+ autoreconf('-fi')
+
+ def configure_args(self):
+ spec = self.spec
+ prefix = self.prefix
+
+ python_version = spec['python'].version.up_to(2)
+ pyyaml = join_path(spec['py-pyyaml'].prefix.lib,
+ 'python{0}'.format(python_version))
+
+ openmp_flag = []
+ if '+openmp' in spec:
+ openmp_flag.append(self.compiler.openmp_flag)
+
+ linalg = []
+ if '+scalapack' in spec:
+ linalg.append(spec['scalapack'].libs.ld_flags)
+ linalg.append(spec['lapack'].libs.ld_flags)
+ linalg.append(spec['blas'].libs.ld_flags)
+
+ args = [
+ "FCFLAGS=%s" % " ".join(openmp_flag),
+ "--with-ext-linalg=%s" % " ".join(linalg),
+ "--with-pyyaml-path=%s" % pyyaml,
+ "--with-futile-libs=%s" % spec['bigdft-futile'].prefix.lib,
+ "--with-futile-incs=%s" % spec['bigdft-futile'].headers.include_flags,
+ "--with-psolver-libs=%s" % spec['bigdft-psolver'].prefix.lib,
+ "--with-psolver-incs=%s" % spec['bigdft-psolver'].headers.include_flags,
+ "--with-core-libs=%s" % spec['bigdft-core'].prefix.lib,
+ "--with-core-incs=%s" % spec['bigdft-core'].headers.include_flags,
+ "--with-moduledir=%s" % prefix.include,
+ "--prefix=%s" % prefix,
+ ]
+
+ if '+mpi' in spec:
+ args.append("CC=%s" % spec['mpi'].mpicc)
+ args.append("CXX=%s" % spec['mpi'].mpicxx)
+ args.append("FC=%s" % spec['mpi'].mpifc)
+ args.append("F90=%s" % spec['mpi'].mpifc)
+ args.append("F77=%s" % spec['mpi'].mpif77)
+ else:
+ args.append("--disable-mpi")
+
+ if '+openmp' in spec:
+ args.append("--with-openmp")
+ else:
+ args.append("--without-openmp")
+
+ return args
+
+ @property
+ def libs(self):
+ shared = "+shared" in self.spec
+ return find_libraries(
+ 'libspred-*', root=self.prefix, shared=shared, recursive=True
+ )
diff --git a/var/spack/repos/builtin/packages/bigdft-suite/package.py b/var/spack/repos/builtin/packages/bigdft-suite/package.py
new file mode 100644
index 0000000000..a5dd855ea8
--- /dev/null
+++ b/var/spack/repos/builtin/packages/bigdft-suite/package.py
@@ -0,0 +1,39 @@
+# Copyright 2013-2021 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)
+
+from spack import *
+
+
+class BigdftSuite(BundlePackage):
+ """BigDFT-suite: the complete suite of BigDFT for electronic structure calculation
+ based on Daubechies wavelets."""
+
+ homepage = "https://bigdft.org/"
+ url = "https://gitlab.com/l_sim/bigdft-suite/-/archive/1.9.2/bigdft-suite-1.9.2.tar.gz"
+ git = "https://gitlab.com/l_sim/bigdft-suite.git"
+
+ version('develop', branch='devel')
+ version('1.9.2', sha256='dc9e49b68f122a9886fa0ef09970f62e7ba21bb9ab1b86be9b7d7e22ed8fbe0f')
+ version('1.9.1', sha256='3c334da26d2a201b572579fc1a7f8caad1cbf971e848a3e10d83bc4dc8c82e41')
+ version('1.9.0', sha256='4500e505f5a29d213f678a91d00a10fef9dc00860ea4b3edf9280f33ed0d1ac8')
+ version('1.8.3', sha256='f112bb08833da4d11dd0f14f7ab10d740b62bc924806d77c985eb04ae0629909')
+ version('1.8.2', sha256='042e5a3b478b1a4c050c450a9b1be7bcf8e13eacbce4759b7f2d79268b298d61')
+ version('1.8.1', sha256='e09ff0ba381f6ffbe6a3c0cb71db5b73117874beb41f22a982a7e5ba32d018b3')
+
+ depends_on('python@:2.8', type=('run'), when="@:1.8.3")
+ depends_on('python@3.0:', type=('run'), when="@1.9.0:")
+ depends_on('python@3.0:', type=('run'), when="@develop")
+
+ for vers in ['1.8.1', '1.8.2', '1.8.3', '1.9.0', '1.9.1', '1.9.2', 'develop']:
+ depends_on('bigdft-futile@{0}'.format(vers), when='@{0}'.format(vers))
+ depends_on('bigdft-psolver@{0}'.format(vers), when='@{0}'.format(vers))
+ depends_on('bigdft-libabinit@{0}'.format(vers), when='@{0}'.format(vers))
+ depends_on('bigdft-chess@{0}'.format(vers), when='@{0}'.format(vers))
+ depends_on('bigdft-core@{0}'.format(vers), when='@{0}'.format(vers))
+ depends_on('bigdft-spred@{0}'.format(vers), when='@{0}'.format(vers))
+ for vers in ['1.8.3', '1.9.0', '1.9.1', '1.9.2', 'develop']:
+ depends_on('bigdft-atlab@{0}'.format(vers), when='@{0}'.format(vers))
+ for vers in ['1.9.0', '1.9.1', '1.9.2', 'develop']:
+ depends_on('py-bigdft@{0}'.format(vers), when='@{0}'.format(vers))
diff --git a/var/spack/repos/builtin/packages/libgain/package.py b/var/spack/repos/builtin/packages/libgain/package.py
new file mode 100644
index 0000000000..30a6ebeabf
--- /dev/null
+++ b/var/spack/repos/builtin/packages/libgain/package.py
@@ -0,0 +1,25 @@
+# Copyright 2013-2021 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)
+
+from spack import *
+
+
+class Libgain(AutotoolsPackage):
+ """GaIn is intended to provide routines with a relatively simple interface
+ for calculation of overlap, kinetic and 2,3 and 4 center Coulomb integrals
+ over either Solid or Cubic Harmonics Gaussian basis sets."""
+
+ homepage = "https://bigdft.org/"
+ git = "https://gitlab.com/l_sim/bigdft-suite.git"
+
+ version('1.0.0', sha256='3e02637433272f5edfee74ea47abf93ab7e3f1ce717664d22329468a5bd45c3a',
+ url="https://gitlab.com/l_sim/bigdft-suite/-/raw/1.9.1/GaIn-1.0.tar.gz")
+
+ @property
+ def libs(self):
+ shared = "+shared" in self.spec
+ return find_libraries(
+ 'libGaIn', root=self.prefix, shared=shared, recursive=True
+ )
diff --git a/var/spack/repos/builtin/packages/py-bigdft/package.py b/var/spack/repos/builtin/packages/py-bigdft/package.py
new file mode 100644
index 0000000000..2566e4d34f
--- /dev/null
+++ b/var/spack/repos/builtin/packages/py-bigdft/package.py
@@ -0,0 +1,31 @@
+# Copyright 2013-2021 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)
+
+from spack import *
+
+
+class PyBigdft(PythonPackage):
+ """BigDFT: the python interface of BigDFT for electronic structure calculation
+ based on Daubechies wavelets."""
+
+ homepage = "https://bigdft.org/"
+ url = "https://gitlab.com/l_sim/bigdft-suite/-/archive/1.9.2/bigdft-suite-1.9.2.tar.gz"
+ git = "https://gitlab.com/l_sim/bigdft-suite.git"
+
+ version('develop', branch='devel')
+ version('1.9.2', sha256='dc9e49b68f122a9886fa0ef09970f62e7ba21bb9ab1b86be9b7d7e22ed8fbe0f')
+ version('1.9.1', sha256='3c334da26d2a201b572579fc1a7f8caad1cbf971e848a3e10d83bc4dc8c82e41')
+ version('1.9.0', sha256='4500e505f5a29d213f678a91d00a10fef9dc00860ea4b3edf9280f33ed0d1ac8')
+
+ depends_on('python@:2.8', type=('build', 'run'), when="@:1.8.3")
+ depends_on('python@3.0:', type=('build', 'run'), when="@1.9.0:")
+ depends_on('python@3.0:', type=('build', 'run'), when="@develop")
+ depends_on('py-numpy')
+ depends_on('py-setuptools')
+
+ for vers in ['1.9.0', '1.9.1', '1.9.2', 'develop']:
+ depends_on('bigdft-futile@{0}'.format(vers), type='run', when='@{0}'.format(vers))
+
+ build_directory = "PyBigDFT"