CEED 1.0 (#7423)
* ceed bundle package including OCCA, MAGMA, Nek5000, mfem, and PETSc Very preliminary, a lot of ad hoc decisions, fragile, missing functionality All packages do build on my MacOS laptop with Cuda Funded-by: ECP Project: CEED Time: 4 hours Reported-by: Tzanio Kolev <kolev1@llnl.gov> * Some adjustments in a few CEED-related packages. This is still very preliminary, but with these changes I'm able to build from scratch on a Mac laptop and a Linux desktop (RHEL7). Note that there doesn't seem to be a good way to support CUDA in Spack, so you'll have to install that manually yourself. You will also need a Fortran compiler, in particular on a Mac where you also have to make sure that it is being picked up in ~/.spack/darwin/compilers.yaml. * ceed bundle package including OCCA, MAGMA, Nek5000, mfem, and PETSc Very preliminary, a lot of ad hoc decisions, fragile, missing functionality All packages do build on my MacOS laptop with Cuda Funded-by: ECP Project: CEED Time: 4 hours Reported-by: Tzanio Kolev <kolev1@llnl.gov> * Reverting Mac-related CUDA checks in the OCCA and MAGMA packages. A much better solution is to install CUDA manually and add it to ~/.spack/darwin/packages.yaml: packages: cuda: paths: cuda@8.0.54: /usr/local/cuda * Fix flake8 warnings Funded-by: CEED Project: CEED/Spack * remove unneeded commented out code Funded-by: CEED Project: CEED/Spack * Don't have PETSc use MUMPS to speedup install time, try parallel installs for Magma Funded-by: CEED Project: CEED/Spack * Added libceed package and made changes to get the ceed metapackage up and running. * Get the ceed package up and running and added installing the .h file in the libceed package. * All packages are now pointed at specific versions (either tagged or git hashed. * Changed some of the specific versions in the CEED metapackage. * Some version updates. * Applied Cameron Smith's patch for the latest pumi. * Merge * Nek5000: Use tarball instead of git tag * Major update of the mfem package - needs more testing. Add a testing shell script for mfem, test_builds.sh, in the mfem directory. It builds a number of mfem configurations to ensure they all work. Add 'suite-sparse' variant to petsc. Add 'develop' version of libceed. Add 'metis' variant of laghos. Update the dependencies of ceed. * Changes in petsc's handling of zlib to make the latest build work on Mac. * [MFEM] When using '+libunwind', mfem needs '-ldl'. * [OCCA] Remove debug print statements. * [PETSc] Replace the check ('zlib' in spec) with ('+zlib' in spec) - the latter checks if 'zlib' variant of petsc is enabled which is incorrect; the former checks if petsc is configured to depend on 'zlib'. * [MFEM] Add conduit variant. * [libCEED] Enable testing using 'make prove'. * [MFEM] Tweak test_builds.sh - all builds pass on fedora 27. * Add a post install test * Add a post installation check for NekCEM * pumi: bump git hash, remove unused patch * Fixed testing of Laghos package * Adding variants in CEED package * Empty file for URL didn't work on LLNL/LC. Replacing with bundle-package.txt -> README.md. * [MFEM] If the spec defines the 'cxxflags' compiler flags, use that value to set the CXXFLAGS value in the mfem build system. * Disabling HDF5 by default. You can still build it with "spack install ceed+hdf5". * libceed: fix use of prefix versus DESTDIR * Added cuda variant for libCEED (off by default) * [libCEED] When building v0.1, fix ceed.pc before installing it. * [CEED] Add variants for OCCA and PUMI. Replace the hdf5 variant with a variant called quickbuild that disables variants in packages to speedup the build - currently hdf5, boost, and superlu-dist in PETSc. * [libCEED] Remove unused 'import os'. * [MAGMA] Add version 2.3.0. * [OCCA] Major update of occa/package.py. * [libCEED] Several improvements. * [CEED] Use fixed versions for occa and libceed. * [OCCA] Fix a bug in CUDA setup. * NekCEM doesn't need depends_on('python') * [OCCA,libCEED,MFEM,CEED] Update occa and libceed versions plus a few tweaks in occa and mfem. * Switching to gslib-1.0.2 to fix summitdev bug. * [Nek5000] Use the Fortran 77 compiler instead of the 'fc' compiler. Propagate any 'fflags' and 'cflags' specifications to the Nek tools. * [MFEM] Tweak for 'ppc64le'. * attempt to override fips compatibility error for md5 * Compiler option changes in libCEED to fix summitdev build. * Disable the nekcem install test until it can be fixed. * [NekCEM] Major update of the package to fix various issues. * [NekCEM] Fix formatting * zoltan: remove non-portable -g0 flag the pgi compiler does not accept it * pumi: specify dependency on cmake > 3 * [Nek5000] Add dependency on libx11 when needed. Various hacks to support IBM XL compilers. * [NekCEM] Link with the pthreads library - it is required. * [MAGMA] Add a patch for magma v2.3.0 when building with gcc <= 4.8. Add dependency on BLAS. * [CEED] Update to magma 2.3.0. When building with gcc < 4.9 constrain the used suite-sparse version to <= 5.1.0 - starting with v5.2.0, suite-sparse requires gcc >= 4.9. * Small updates * [libceed, gslib] Fix style * [Nek5000] Need 'libxt' as a dependency as well. * [MUMPS] Temporary workaround for ray. * Updating occa and libceed to laters pre-1.0.0 and pre-0.2 hashes * petsc: add pkg-config patch for variable quoting Variable definitions in pkg-config are processed more like make than a shell, so don't need quoting. Older versions of pkg-config (<= 0.28) did not remove the quotes when printing the value. Freedesktop #67904 (https://bugs.freedesktop.org/show_bug.cgi?id=67904) Reported-by: Tzanio Kolev <kolev1@llnl.gov> * petsc: add 3.8.4 and myself as co-maintainer * Updating libceed to latest pre-0.2 hash. * [PETSc] Add the 'headers' and 'libs' properties. * [MFEM] Explicitly add rpaths to link flags for external packages. This is necessary when MFEM's exported options (in config.mk) are used outside of Spack for linking against MFEM. * Unset MFEM_DIR before building MFEM * [PETSc] As observed by @jedbrown, there is no need to define the 'libs' property explicitly - the default handler works fine too. * Build MAGMA shared by default, install a few additional headers * Forgot a self * Switching to OCCA tag v1.0.0-alpha.4. Adding urls for OCCA and libCEED ('spack uninstall' complains otherwise). * Removed FIXMEs for OCCA tag * [occa] Cleaned up tagged versions * [libceed] Updated occa to v1.0.0-alpha.5 * [ceed] Updated occa to v1.0.0-alpha.5 * [libCEED] Always define the 'NDEBUG' makefile option based on the 'debug' variant setting - this should always work regardless of the default setting inside the libceed makefile. * [MUMPS] Revert a temporary workaround. * [CEED, libCEED] Minor tweaks. * libCEED v0.2 release * [CEED] Use version 0.2 of libCEED. * [HPGMG] Remove duplicate version. * [CEED] Update the hpgmg version * hpgmg: use tarball for 0.3 The Git repository contains somewhat heavy documentation so the tarballs are much faster. * hpgmg: +fe was default for the 0.3 release * hpgmg: explicitly name build directory to avoid use of ambient PETSC_ARCH * [HPGMG] Fix flake8 formatting * libceed@0.2: work around occaFree issue
This commit is contained in:

committed by
Veselin Dobrev

parent
b3f6015e32
commit
b62ed20f3f
@@ -0,0 +1,24 @@
|
||||
diff -ru magma-2.3.0/testing/testings.h magma-2.3.0-patched/testing/testings.h
|
||||
--- magma-2.3.0/testing/testings.h 2017-11-14 21:34:00.000000000 -0800
|
||||
+++ magma-2.3.0-patched/testing/testings.h 2018-03-23 20:41:16.459934643 -0700
|
||||
@@ -269,4 +269,20 @@
|
||||
typename blas::traits<FloatT>::real_t* sigma,
|
||||
FloatT* A, magma_int_t lda );
|
||||
|
||||
+// This overload for the case sigma = nullptr is a workaround for an issue
|
||||
+// when building with gcc 4.8.5. This is not an issue with gcc 4.9.2.
|
||||
+template< typename FloatT >
|
||||
+void magma_generate_matrix(
|
||||
+ magma_opts& opts,
|
||||
+ magma_int_t m, magma_int_t n,
|
||||
+ std::nullptr_t sigma,
|
||||
+ FloatT* A, magma_int_t lda )
|
||||
+{
|
||||
+ magma_generate_matrix<FloatT>(
|
||||
+ opts,
|
||||
+ m, n,
|
||||
+ (typename blas::traits<FloatT>::real_t*) sigma,
|
||||
+ A, lda );
|
||||
+}
|
||||
+
|
||||
#endif /* TESTINGS_H */
|
@@ -22,28 +22,37 @@
|
||||
# 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 Magma(CMakePackage):
|
||||
"""The MAGMA project aims to develop a dense linear algebra library
|
||||
similar to LAPACK but for heterogeneous/hybrid architectures,
|
||||
starting with current "Multicore+GPU" systems.
|
||||
"""The MAGMA project aims to develop a dense linear algebra library similar to
|
||||
LAPACK but for heterogeneous/hybrid architectures, starting with current
|
||||
"Multicore+GPU" systems.
|
||||
"""
|
||||
|
||||
homepage = "http://icl.cs.utk.edu/magma/"
|
||||
url = "http://icl.cs.utk.edu/projectsfiles/magma/downloads/magma-2.2.0.tar.gz"
|
||||
|
||||
version('2.3.0', '9aaf85a338d3a17303e0c69f86f0ec52')
|
||||
version('2.2.0', '6c1ebf4cdf63eb302ff6258ff8c49217')
|
||||
|
||||
variant('fortran', default=True,
|
||||
description='Enable Fortran bindings support')
|
||||
variant('shared', default=True,
|
||||
description='Enable shared library')
|
||||
|
||||
depends_on('blas')
|
||||
depends_on('lapack')
|
||||
depends_on('cuda@9.0:', when='%gcc@6.0:6.9.9')
|
||||
depends_on('cuda@8.0:', when='%gcc@5.0:')
|
||||
depends_on('cuda')
|
||||
|
||||
conflicts('%gcc@6:', when='^cuda@:8')
|
||||
conflicts('%gcc@7:', when='^cuda@:9')
|
||||
|
||||
patch('ibm-xl.patch', when='@2.2:%xl')
|
||||
patch('ibm-xl.patch', when='@2.2:%xl_r')
|
||||
patch('magma-2.3.0-gcc-4.8.patch', when='@2.3.0%gcc@:4.8')
|
||||
|
||||
def cmake_args(self):
|
||||
spec = self.spec
|
||||
@@ -52,10 +61,17 @@ def cmake_args(self):
|
||||
options.extend([
|
||||
'-DCMAKE_INSTALL_PREFIX=%s' % prefix,
|
||||
'-DCMAKE_INSTALL_NAME_DIR:PATH=%s/lib' % prefix,
|
||||
'-DLAPACK_LIBRARIES=%s;%s' % (spec['blas'].libs,
|
||||
spec['lapack'].libs)
|
||||
'-DBLAS_LIBRARIES=%s' % spec['blas'].libs.joined(';'),
|
||||
# As of MAGMA v2.3.0, CMakeLists.txt does not use the variable
|
||||
# BLAS_LIBRARIES, but only LAPACK_LIBRARIES, so we need to
|
||||
# explicitly add blas to LAPACK_LIBRARIES.
|
||||
'-DLAPACK_LIBRARIES=%s' %
|
||||
(spec['lapack'].libs + spec['blas'].libs).joined(';')
|
||||
])
|
||||
|
||||
options += ['-DBUILD_SHARED_LIBS=%s' %
|
||||
('ON' if ('+shared' in spec) else 'OFF')]
|
||||
|
||||
if '+fortran' in spec:
|
||||
options.extend([
|
||||
'-DUSE_FORTRAN=yes'
|
||||
@@ -66,8 +82,16 @@ def cmake_args(self):
|
||||
])
|
||||
|
||||
if spec.satisfies('^cuda@9.0:'):
|
||||
options.extend([
|
||||
'-DGPU_TARGET=sm30'
|
||||
])
|
||||
if '@:2.2.0' in spec:
|
||||
options.extend(['-DGPU_TARGET=sm30'])
|
||||
else:
|
||||
options.extend(['-DGPU_TARGET=sm_30'])
|
||||
|
||||
return options
|
||||
|
||||
@run_after('install')
|
||||
def post_install(self):
|
||||
install('magmablas/atomics.cuh', self.prefix.include)
|
||||
install('control/magma_threadsetting.h', self.prefix.include)
|
||||
install('control/pthread_barrier.h', self.prefix.include)
|
||||
install('control/magma_internal.h', self.prefix.include)
|
||||
|
Reference in New Issue
Block a user