summaryrefslogtreecommitdiff
path: root/var/spack/repos/builtin/packages/wonton/package.py
blob: d395eacf7c1e92c5120a41588b1cffce330db7a9 (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
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
# Copyright 2013-2023 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.package import *
from spack.pkg.builtin.boost import Boost


class Wonton(CMakePackage):
    """Wonton is a support package for the Portage
    (https://github.com/laristra/portage) and Tangram
    (https://github.com/laristra/tangram) libraries. It contains some
    mesh/state classes, wrappers for other mesh/state libraries and
    some utilities required by Portage and Tangram.

    """

    homepage = "https://portage.lanl.gov"
    git = "https://github.com/laristra/wonton.git"
    url = "https://github.com/laristra/wonton/releases/download/1.2.11/wonton-1.2.11.tar.gz"

    maintainers("raovgarimella")

    license("BitTorrent-1.0")

    version("1.3.2", sha256="a03f00cd95290c2dbe8724d430de19537ea644b75161614ed4ac918376fcf64d")
    version("1.2.11", sha256="613436c799b392a99355db1cbf1062f1da39f3287eed665a5cd43bb65364d926")
    version("1.2.10", sha256="c5c2c99f040f1fa5a8da21ac5ccbbc5b226d1fd43ce3eb14c76d211601b65a72")
    version("1.2.1", sha256="4f00513d1abe86f256214d2b5171b1575b2cd464df8609307c24cbc4c595c305")

    variant("lapacke", default=True, description="Use LAPACKE solvers")

    # Variants for controlling parallelism
    variant("mpi", default=False, description="Enable distributed meshes with MPI")
    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")
    variant("flecsi", default=False, description="Enable FlecSI")
    # wrappers to external mesh/state libraries
    variant("jali", default=False, description="Enable Jali mesh wrappers")

    conflicts("+jali ~mpi")  # Jali needs MPI
    conflicts("+thrust +cuda")  # Thrust with CUDA does not work as yet
    conflicts("+thrust +kokkos")  # Don't enable Kokkos, Thrust simultaneously

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

    depends_on("netlib-lapack +lapacke", when="+lapacke")

    depends_on("mpi", when="+mpi")
    depends_on("flecsi", when="+flecsi")

    depends_on("jali@1.1.6", when="@1.3.2: +jali")
    depends_on("jali +mstk", when="+jali")
    depends_on("mpi", when="+jali")

    # NVidia thrust library
    depends_on("thrust@1.8.3", when="+thrust")

    # TODO: replace this with an explicit list of components of Boost,
    # for instance depends_on('boost +filesystem')
    # See https://github.com/spack/spack/pull/22303 for reference
    depends_on(Boost.with_default_variants, when="@:1.2.10 ~thrust")

    # CUDA library
    depends_on("cuda", when="+cuda")

    # Kokkos with appropriate option
    depends_on("kokkos +openmp", when="+kokkos +openmp")
    depends_on("kokkos +cuda", when="+kokkos +cuda")

    # Wonton-provided CMake config files contain some settings that
    # can break host codes; these patches fix that
    patch("fix-cmake-config.patch", when="@1.2.0:1.3.3")
    patch("fix-cmake-config-r3d.patch", when="@1.3.0:1.3.3")

    def cmake_args(self):
        options = []
        if "+mpi" in self.spec:
            options.append("-DWONTON_ENABLE_MPI=ON")
        else:
            options.append("-DWONTON_ENABLE_MPI=OFF")

        if "+lapacke" in self.spec:
            options.append("-DWONTON_ENABLE_LAPACKE=ON")
            options.append("-DBLA_VENDOR=" + self.spec["blas"].name.upper())
            options.append("-DBLAS_LIBRARIES=" + self.spec["blas"].libs.joined())
        else:
            options.append("-DWONTON_ENABLE_LAPACKE=OFF")

        if "+thrust" in self.spec:
            options.append("-DWONTON_ENABLE_THRUST=ON")
            if "+cuda" in self.spec:
                options.append("-DTHRUST_HOST_BACKEND:STRING=THRUST_HOST_SYSTEM_CPP")
                options.append("-DTHRUST_DEVICE_BACKEND:STRING=THRUST_DEVICE_SYSTEM_CUDA")
            else:
                options.append("-DTHRUST_HOST_BACKEND:STRING=THRUST_HOST_SYSTEM_CPP")
                options.append("-DTHRUST_DEVICE_BACKEND:STRING=THRUST_DEVICE_SYSTEM_OMP")
        else:
            options.append("-DWONTON_ENABLE_THRUST=OFF")

        if "+kokkos" in self.spec:
            options.append("-DWONTON_ENABLE_Kokkos=ON")
            if "+cuda" in self.spec:
                options.append("-DWONTON_ENABLE_Kokkos_CUDA=ON")
            elif "+openmp" in self.spec:
                options.append("-DWONTON_ENABLE_Kokkos_OpenMP=ON")
        else:
            options.append("-DWONTON_ENABLE_Kokkos=OFF")

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

        # BROKEN DEPENDENCY!!!!!!
        options.append(self.define_from_variant("WONTON_ENABLE_FleCSI", "flecsi"))

        # 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")