summaryrefslogtreecommitdiff
path: root/var/spack/repos/builtin/packages/portage/package.py
blob: fb12d6ea0ad25be6bad35742a7c793d6d093ed6a (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
# Copyright 2013-2022 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 Portage(CMakePackage):
    """Portage is a framework that computational physics applications can use
       to build a highly customized, hybrid parallel (MPI+X) conservative
       remapping library for transfer of field data between meshes.
    """
    homepage = "https://portage.lanl.gov/"
    git      = "https://github.com/laristra/portage.git"
    url      = "https://github.com/laristra/portage/releases/download/3.0.0/portage-3.0.0.tar.gz"

    maintainers = ['raovgarimella']

    # tarballs don't have submodules, so use git tags
    version('3.0.0', sha256='7a5a21ffbc35fa54a5136d937cfda6f836c7496ff2b5adf54deb4107501333da')
    version('master', branch='master', submodules=True)

    variant('mpi', default=True, description='Support MPI')
    variant('tangram', default=False, description='Use Tangram interface reconstruction package')
    variant('jali', default=False, description='Include support for Jali mesh framework')
    variant('thrust', default=False, description='Enable on-node parallelism using NVidia Thrust library')
    variant('kokkos', default=False, description='Enable on-node or device parallelism with Kokkos')
    variant('openmp', default=False, description="Enable on-node parallelism using OpenMP")
    variant('cuda', default=False, description="Enable GPU parallelism using CUDA")

    depends_on("cmake@3.13:", type='build')

    depends_on('mpi', when='+mpi')
    depends_on('kokkos', when='+kokkos')
    depends_on('thrust', when='+thrust')
    depends_on('jali', when='+jali')

    depends_on('tangram', when='+tangram')

    for _variant in ['mpi', 'jali', 'openmp', 'thrust', 'kokkos', 'cuda']:
        depends_on('tangram+' + _variant, when='+tangram+' + _variant)
        depends_on('tangram~' + _variant, when='+tangram~' + _variant)

    depends_on('wonton')
    # Wonton depends array
    wonton_variant = ['mpi', 'jali', 'openmp', 'thrust', 'kokkos', 'cuda']

    for _variant in wonton_variant:
        depends_on('wonton+' + _variant, when='+' + _variant)
        depends_on('wonton~' + _variant, when='~' + _variant)

    # Jali needs MPI
    conflicts('+jali ~mpi')

    # Thrust with CUDA does not work as yet
    conflicts('+thrust +cuda')

    # Don't enable Kokkos and Thrust simultaneously
    conflicts('+thrust +kokkos')

    def cmake_args(self):
        options = []

        if '+mpi' in self.spec:
            options.append('-DPORTAGE_ENABLE_MPI=ON')
        else:
            options.append('-DPORTAGE_ENABLE_MPI=OFF')

        if '+thrust' in self.spec:
            options.append('-DPORTAGE_ENABLE_THRUST=ON')
        else:
            options.append('-DPORTAGE_ENABLE_THRUST=OFF')

        if '+kokkos' in self.spec:
            options.append('-DPORTAGE_ENABLE_Kokkos=ON')
        else:
            options.append('-DPORTAGE_ENABLE_Kokkos=OFF')

        if '+jali' in self.spec:
            options.append('-DPORTAGE_ENABLE_Jali=ON')
        else:
            options.append('-DPORTAGE_ENABLE_Jali=OFF')

        if '+flecsisp' in self.spec:
            options.append('-DPORTAGE_ENABLE_FleCSI=ON')
        else:
            options.append('-DPORTAGE_ENABLE_FleCSI=OFF')

        if '+tangram' in self.spec:
            options.append('-DPORTAGE_ENABLE_TANGRAM=ON')
        else:
            options.append('-DPORTAGE_ENABLE_TANGRAM=OFF')

        # Unit test variant
        if self.run_tests:
            options.append('-DENABLE_UNIT_TESTS=ON')
            options.append('-DENABLE_APP_TESTS=ON')
        else:
            options.append('-DENABLE_UNIT_TESTS=OFF')
            options.append('-DENABLE_APP_TESTS=OFF')

        return options

    def check(self):
        if self.run_tests:
            with working_dir(self.build_directory):
                ctest("-j 8")