spack/var/spack/repos/builtin/packages/slurm/package.py
Robert Mijakovic 187c23d3c5
Slurm: add v20-11-[4,5]-1 (#22416)
Co-authored-by: Robert Mijakovic <robert.mijakovic@lrz.de>
2021-03-20 00:09:32 +01:00

137 lines
5.3 KiB
Python

# 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 Slurm(AutotoolsPackage):
"""Slurm is an open source, fault-tolerant, and highly scalable cluster
management and job scheduling system for large and small Linux clusters.
Slurm requires no kernel modifications for its operation and is relatively
self-contained. As a cluster workload manager, Slurm has three key
functions. First, it allocates exclusive and/or non-exclusive access to
resources (compute nodes) to users for some duration of time so they can
perform work. Second, it provides a framework for starting, executing,
and monitoring work (normally a parallel job) on the set of allocated
nodes. Finally, it arbitrates contention for resources by managing a
queue of pending work.
"""
homepage = 'https://slurm.schedmd.com'
url = 'https://github.com/SchedMD/slurm/archive/slurm-19-05-6-1.tar.gz'
version('20-11-5-1', sha256='d0634c6c6cc79bde38d19f0ef0de0de3b07907830f5e45be6f4a9ca4259f8f67')
version('20-11-4-1', sha256='06c5333e85f531730bf1c6eb48a8d48a551d9090540ce37b78181024273fb6bd')
version('20-11-0-1', sha256='404f72c287c5aad887a5b141304e4962548c12f79b04fc9c88550bc024604228')
version('20-02-4-1', sha256='d32a39df20a99430973de6692870269f38443d8b963c32b4d6475c9d5e92cd73')
version('19-05-6-1', sha256='1b83bce4260af06d644253b1f2ec2979b80b4418c631e9c9f48c2729ae2c95ba')
version('19-05-5-1', sha256='e53e67bd0bb4c37a9c481998764a746467a96bc41d6527569080514f36452c07')
version('18-08-9-1', sha256='32eb0b612ca18ade1e35c3c9d3b4d71aba2b857446841606a9e54d0a417c3b03')
version('18-08-0-1', sha256='62129d0f2949bc8a68ef86fe6f12e0715cbbf42f05b8da6ef7c3e7e7240b50d9')
version('17-11-9-2', sha256='6e34328ed68262e776f524f59cca79ac75bcd18030951d45ea545a7ba4c45906')
version('17-02-6-1', sha256='97b3a3639106bd6d44988ed018e2657f3d640a3d5c105413d05b4721bc8ee25e')
variant('gtk', default=False, description='Enable GTK+ support')
variant('mariadb', default=False, description='Use MariaDB instead of MySQL')
variant('hwloc', default=False, description='Enable hwloc support')
variant('hdf5', default=False, description='Enable hdf5 support')
variant('readline', default=True, description='Enable readline support')
variant('pmix', default=False, description='Enable PMIx support')
variant('sysconfdir', default='PREFIX/etc', values=any,
description='Set system configuration path (possibly /etc/slurm)')
variant('restd', default=False, description='Enable the slurmrestd server')
# TODO: add variant for BG/Q and Cray support
# TODO: add support for checkpoint/restart (BLCR)
# TODO: add support for lua
depends_on('curl')
depends_on('glib')
depends_on('json-c')
depends_on('lz4')
depends_on('munge')
depends_on('openssl')
depends_on('pkgconfig', type='build')
depends_on('readline', when='+readline')
depends_on('zlib')
depends_on('gtkplus', when='+gtk')
depends_on('hdf5', when='+hdf5')
depends_on('hwloc', when='+hwloc')
depends_on('mariadb', when='+mariadb')
depends_on('pmix', when='+pmix')
depends_on('http-parser', when='+restd')
depends_on('libyaml', when='+restd')
depends_on('libjwt', when='+restd')
def flag_handler(self, name, flags):
wrapper_flags = None
if name == 'cflags':
if self.spec.satisfies('@:20-02-1 %gcc@10:'):
wrapper_flags = ['-fcommon']
return (wrapper_flags, None, flags)
def configure_args(self):
spec = self.spec
args = [
'--with-libcurl={0}'.format(spec['curl'].prefix),
'--with-json={0}'.format(spec['json-c'].prefix),
'--with-lz4={0}'.format(spec['lz4'].prefix),
'--with-munge={0}'.format(spec['munge'].prefix),
'--with-ssl={0}'.format(spec['openssl'].prefix),
'--with-zlib={0}'.format(spec['zlib'].prefix),
]
if '~gtk' in spec:
args.append('--disable-gtktest')
if '~readline' in spec:
args.append('--without-readline')
if '+hdf5' in spec:
args.append(
'--with-hdf5={0}'.format(spec['hdf5'].prefix.bin.h5cc)
)
else:
args.append('--without-hdf5')
if '+restd' in spec:
args.append('--enable-slurmrestd')
args.append('--with-http-parser={0}'.format(
spec['http-parser'].prefix))
args.append('--with-jwt={0}'.format(spec['libjwt'].prefix))
else:
args.append('--disable-slurmrestd')
if '+hwloc' in spec:
args.append('--with-hwloc={0}'.format(spec['hwloc'].prefix))
else:
args.append('--without-hwloc')
if '+pmix' in spec:
args.append('--with-pmix={0}'.format(spec['pmix'].prefix))
else:
args.append('--without-pmix')
sysconfdir = spec.variants['sysconfdir'].value
if sysconfdir != 'PREFIX/etc':
args.append('--sysconfdir={0}'.format(sysconfdir))
return args
def install(self, spec, prefix):
make('install')
make('-C', 'contribs/pmi2', 'install')