-
Notifications
You must be signed in to change notification settings - Fork 355
/
CMakeLists.txt
104 lines (93 loc) · 3.76 KB
/
CMakeLists.txt
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
#
# Copyright 2023 NVIDIA Corporation. All rights reserved.
#
# NOTICE TO LICENSEE:
#
# This source code and/or documentation ("Licensed Deliverables") are
# subject to NVIDIA intellectual property rights under U.S. and
# international Copyright laws.
#
# These Licensed Deliverables contained herein is PROPRIETARY and
# CONFIDENTIAL to NVIDIA and is being provided under the terms and
# conditions of a form of NVIDIA software license agreement by and
# between NVIDIA and Licensee ("License Agreement") or electronically
# accepted by Licensee. Notwithstanding any terms or conditions to
# the contrary in the License Agreement, reproduction or disclosure
# of the Licensed Deliverables to any third party without the express
# written consent of NVIDIA is prohibited.
#
# NOTWITHSTANDING ANY TERMS OR CONDITIONS TO THE CONTRARY IN THE
# LICENSE AGREEMENT, NVIDIA MAKES NO REPRESENTATION ABOUT THE
# SUITABILITY OF THESE LICENSED DELIVERABLES FOR ANY PURPOSE. IT IS
# PROVIDED "AS IS" WITHOUT EXPRESS OR IMPLIED WARRANTY OF ANY KIND.
# NVIDIA DISCLAIMS ALL WARRANTIES WITH REGARD TO THESE LICENSED
# DELIVERABLES, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY,
# NONINFRINGEMENT, AND FITNESS FOR A PARTICULAR PURPOSE.
# NOTWITHSTANDING ANY TERMS OR CONDITIONS TO THE CONTRARY IN THE
# LICENSE AGREEMENT, IN NO EVENT SHALL NVIDIA BE LIABLE FOR ANY
# SPECIAL, INDIRECT, INCIDENTAL, OR CONSEQUENTIAL DAMAGES, OR ANY
# DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS,
# WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS
# ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE
# OF THESE LICENSED DELIVERABLES.
#
# U.S. Government End Users. These Licensed Deliverables are a
# "commercial item" as that term is defined at 48 C.F.R. 2.101 (OCT
# 1995), consisting of "commercial computer software" and "commercial
# computer software documentation" as such terms are used in 48
# C.F.R. 12.212 (SEPT 1995) and is provided to the U.S. Government
# only as a commercial end item. Consistent with 48 C.F.R.12.212 and
# 48 C.F.R. 227.7202-1 through 227.7202-4 (JUNE 1995), all
# U.S. Government End Users acquire the Licensed Deliverables with
# only those rights set forth herein.
#
# Any use of the Licensed Deliverables in individual and commercial
# software must include, in the user documentation and internal
# comments to the code, the above Disclaimer and U.S. Government End
# Users Notice.
#
cmake_minimum_required(VERSION 3.16)
project(cublasmp_samples LANGUAGES CXX CUDA)
find_package(MPI REQUIRED)
set(CMAKE_CUDA_STANDARD 11)
set(CMAKE_CUDA_STANDARD_REQUIRED ON)
set(CUDA_RUNTIME_LIBRARY shared)
if (CAL_MPI_INCLUDE_PATH AND CAL_MPI_LIBRARIES)
add_definitions(-DUSE_CAL_MPI)
endif ()
function(build_sample sample_name)
add_executable(${sample_name} ${sample_name}.cu)
target_include_directories(${sample_name} PUBLIC
${CMAKE_CURRENT_SOURCE_DIR}
${CMAKE_CUDA_TOOLKIT_INCLUDE_DIRECTORIES}
${MPI_CXX_INCLUDE_DIRS}
${CAL_INCLUDE_DIRECTORIES}
${CUBLASMP_INCLUDE_DIRECTORIES}
${CAL_MPI_INCLUDE_PATH}
${NVSHMEM_INCLUDE_DIRECTORIES}
)
target_link_directories(${sample_name} PUBLIC
${CMAKE_CUDA_IMPLICIT_LINK_DIRECTORIES}
${CMAKE_CUDA_IMPLICIT_LINK_DIRECTORIES}/stubs
)
target_link_libraries(${sample_name} PUBLIC
cudart
${CUBLASMP_LIBRARIES}
${CAL_LIBRARIES}
${MPI_CXX_LIBRARIES}
${NVSHMEM_HOST_LIBRARIES}
${NVSHMEM_DEVICE_LIBRARIES}
nvidia-ml
m
${CAL_MPI_LIBRARIES}
)
install(TARGETS ${sample_name}
DESTINATION "bin/"
)
endfunction(build_sample)
build_sample("pgemm")
build_sample("pmatmul")
build_sample("ptrsm")
build_sample("psyrk")
build_sample("pgeadd")
build_sample("ptradd")