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
|
# 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 *
class Kripke(CMakePackage, CudaPackage, ROCmPackage):
"""Kripke is a simple, scalable, 3D Sn deterministic particle
transport proxy/mini app.
"""
homepage = "https://computing.llnl.gov/projects/co-design/kripke"
git = "https://github.com/LLNL/Kripke.git"
tags = ["proxy-app"]
maintainers("vsrana01")
license("BSD-3-Clause")
version("develop", branch="develop", submodules=False)
version(
"1.2.4", submodules=False, tag="v1.2.4", commit="d85c6bc462f17a2382b11ba363059febc487f771"
)
version(
"1.2.3", submodules=True, tag="v1.2.3", commit="66046d8cd51f5bcf8666fd8c810322e253c4ce0e"
)
version(
"1.2.2",
submodules=True,
tag="v1.2.2-CORAL2",
commit="a12bce71e751f8f999009aa2fd0839b908b118a4",
)
version(
"1.2.1",
submodules=True,
tag="v1.2.1-CORAL2",
commit="c36453301ddd684118bb0fb426cfa62764d42398",
)
version(
"1.2.0",
submodules=True,
tag="v1.2.0-CORAL2",
commit="67e4b0a2f092009d61f44b5122111d388a3bec2a",
)
variant("mpi", default=True, description="Build with MPI.")
variant("openmp", default=False, description="Build with OpenMP enabled.")
variant("caliper", default=False, description="Build with Caliper support enabled.")
depends_on("mpi", when="+mpi")
depends_on("blt", type="build")
depends_on("caliper", when="+caliper")
depends_on("chai~examples+raja")
depends_on("raja~exercises~examples")
depends_on("umpire~examples")
conflicts("^blt@:0.3.6", when="+rocm")
def cmake_args(self):
spec = self.spec
args = []
args.extend(
[
"-DCAMP_DIR=%s" % self.spec["camp"].prefix,
"-DBLT_SOURCE_DIR=%s" % self.spec["blt"].prefix,
"-Dumpire_DIR=%s" % self.spec["umpire"].prefix,
"-DRAJA_DIR=%s" % self.spec["raja"].prefix,
"-Dchai_DIR=%s" % self.spec["chai"].prefix,
"-DENABLE_CHAI=ON",
]
)
if "+caliper" in spec:
args.append("-DENABLE_CALIPER=ON")
if "+mpi" in spec:
args.append("-DENABLE_MPI=ON")
args.append(self.define("CMAKE_CXX_COMPILER", self.spec["mpi"].mpicxx))
if "+rocm" in spec:
# Set up the hip macros needed by the build
args.append("-DENABLE_HIP=ON")
args.append("-DHIP_ROOT_DIR={0}".format(spec["hip"].prefix))
rocm_archs = spec.variants["amdgpu_target"].value
if "none" not in rocm_archs:
args.append("-DHIP_HIPCC_FLAGS=--amdgpu-target={0}".format(",".join(rocm_archs)))
args.append("-DCMAKE_HIP_ARCHITECTURES={0}".format(rocm_archs))
else:
# Ensure build with hip is disabled
args.append("-DENABLE_HIP=OFF")
if "+cuda" in spec:
args.append("-DENABLE_CUDA=ON")
args.append(self.define("CMAKE_CUDA_HOST_COMPILER", self.spec["mpi"].mpicxx))
if not spec.satisfies("cuda_arch=none"):
cuda_arch = spec.variants["cuda_arch"].value
args.append("-DCUDA_ARCH={0}".format(cuda_arch[0]))
args.append("-DCMAKE_CUDA_ARCHITECTURES={0}".format(cuda_arch[0]))
args.append(
"-DCMAKE_CUDA_FLAGS=--expt-extended-lambda -I%s -I=%s"
% (self.spec["cub"].prefix.include, self.spec["mpi"].prefix.include)
)
else:
args.append("-DENABLE_CUDA=OFF")
return args
def install(self, spec, prefix):
# Kripke does not provide install target, so we have to copy
# things into place.
mkdirp(prefix.bin)
install(join_path(self.build_directory, "kripke.exe"), prefix.bin)
|