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