|
| 1 | +# Copyright 2013-2024 Lawrence Livermore National Security, LLC and other |
| 2 | +# Spack Project Developers. See the top-level COPYRIGHT file for details. |
| 3 | +# |
| 4 | +# SPDX-License-Identifier: (Apache-2.0 OR MIT) |
| 5 | + |
| 6 | +from spack.package import * |
| 7 | + |
| 8 | + |
| 9 | +class TiledMm(CMakePackage, CudaPackage, ROCmPackage): |
| 10 | + """Matrix multiplication on GPUs for matrices stored on a CPU. Similar to cublasXt, |
| 11 | + but ported to both NVIDIA and AMD GPUs.""" |
| 12 | + |
| 13 | + homepage = "https://github.com/eth-cscs/Tiled-MM/" |
| 14 | + url = "https://github.com/eth-cscs/Tiled-MM/archive/refs/tags/v2.0.tar.gz" |
| 15 | + git = "https://github.com/eth-cscs/Tiled-MM.git" |
| 16 | + |
| 17 | + maintainers("mtaillefumier", "simonpintarelli", "RMeli") |
| 18 | + |
| 19 | + license("BSD-3-Clause") |
| 20 | + |
| 21 | + version("master", branch="master") |
| 22 | + |
| 23 | + version("2.3.1", sha256="68914a483e62f796b790ea428210b1d5ef5943d6289e53d1aa62f56a20fbccc8") |
| 24 | + version("2.3", sha256="504c6201f5a9be9741c55036bf8e2656ae3f4bc19996295b264ee5e303c9253c") |
| 25 | + version("2.2", sha256="6d0b49c9588ece744166822fd44a7bc5bec3dc666b836de8bf4bf1a7bb675aac") |
| 26 | + version("2.0", sha256="ea554aea8c53d7c8e40044e6d478c0e8137d7e8b09d7cb9650703430d92cf32e") |
| 27 | + |
| 28 | + variant("shared", default=True, description="Build shared libraries") |
| 29 | + variant("examples", default=False, description="Enable examples") |
| 30 | + variant("tests", default=False, description="Enable tests") |
| 31 | + |
| 32 | + depends_on("rocblas", when="+rocm") |
| 33 | + depends_on("cxxopts", when="+tests") |
| 34 | + depends_on("cxxopts", when="+examples") |
| 35 | + |
| 36 | + conflicts("~cuda~rocm") |
| 37 | + conflicts("+cuda", when="+rocm") |
| 38 | + |
| 39 | + def cmake_args(self): |
| 40 | + args = [ |
| 41 | + self.define_from_variant("BUILD_SHARED_LIBS", "shared"), |
| 42 | + self.define_from_variant("TILEDMM_WITH_EXAMPLES", "examples"), |
| 43 | + self.define_from_variant("TILEDMM_WITH_TESTS", "tests"), |
| 44 | + ] |
| 45 | + |
| 46 | + if "+rocm" in self.spec: |
| 47 | + args.extend([self.define("TILEDMM_GPU_BACKEND", "ROCM")]) |
| 48 | + |
| 49 | + if "+cuda" in self.spec: |
| 50 | + args.extend([self.define("TILEDMM_GPU_BACKEND", "CUDA")]) |
| 51 | + |
| 52 | + return args |
0 commit comments