A new package: legion (#3738)
This commit is contained in:
parent
3232c16d0c
commit
10ceed3b66
1 changed files with 62 additions and 0 deletions
62
var/spack/repos/builtin/packages/legion/package.py
Normal file
62
var/spack/repos/builtin/packages/legion/package.py
Normal file
|
@ -0,0 +1,62 @@
|
||||||
|
##############################################################################
|
||||||
|
# Copyright (c) 2017, Los Alamos National Security, LLC
|
||||||
|
# Produced at the Los Alamos 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/llnl/spack
|
||||||
|
# Please also see the LICENSE file 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 *
|
||||||
|
|
||||||
|
|
||||||
|
class Legion(CMakePackage):
|
||||||
|
"""Legion is a data-centric parallel programming system for writing
|
||||||
|
portable high performance programs targeted at distributed heterogeneous
|
||||||
|
architectures. Legion presents abstractions which allow programmers to
|
||||||
|
describe properties of program data (e.g. independence, locality). By
|
||||||
|
making the Legion programming system aware of the structure of program
|
||||||
|
data, it can automate many of the tedious tasks programmers currently
|
||||||
|
face, including correctly extracting task- and data-level parallelism
|
||||||
|
and moving data around complex memory hierarchies. A novel mapping
|
||||||
|
interface provides explicit programmer controlled placement of data in
|
||||||
|
the memory hierarchy and assignment of tasks to processors in a way
|
||||||
|
that is orthogonal to correctness, thereby enabling easy porting and
|
||||||
|
tuning of Legion applications to new architectures.
|
||||||
|
"""
|
||||||
|
homepage = "http://legion.stanford.edu/"
|
||||||
|
url = "https://github.com/StanfordLegion/legion/tarball/legion-17.02.0"
|
||||||
|
|
||||||
|
version('develop', git='https://github.com/StanfordLegion/legion', branch='master')
|
||||||
|
version('17.02.0', '31ac3004e2fb0996764362d2b6f6844a')
|
||||||
|
|
||||||
|
variant('debug', default=False, description='Build debug version')
|
||||||
|
|
||||||
|
depends_on("cmake@3.1:", type='build')
|
||||||
|
depends_on("gasnet")
|
||||||
|
|
||||||
|
def build_type(self):
|
||||||
|
spec = self.spec
|
||||||
|
if '+debug' in spec:
|
||||||
|
return 'Debug'
|
||||||
|
else:
|
||||||
|
return 'Release'
|
||||||
|
|
||||||
|
def cmake_args(self):
|
||||||
|
return ['-DLegion_USE_GASNet=ON', '-DLegion_BUILD_EXAMPLES=ON']
|
Loading…
Reference in a new issue