aboutsummaryrefslogtreecommitdiffstats
path: root/build/platform/cuda
diff options
context:
space:
mode:
authorsomov <somov@yandex-team.ru>2022-02-10 16:45:49 +0300
committerDaniil Cherednik <dcherednik@yandex-team.ru>2022-02-10 16:45:49 +0300
commit7489e4682331202b9c7d863c0898eb83d7b12c2b (patch)
tree9142afc54d335ea52910662635b898e79e192e49 /build/platform/cuda
parenta5950576e397b1909261050b8c7da16db58f10b1 (diff)
downloadydb-7489e4682331202b9c7d863c0898eb83d7b12c2b.tar.gz
Restoring authorship annotation for <somov@yandex-team.ru>. Commit 2 of 2.
Diffstat (limited to 'build/platform/cuda')
-rw-r--r--build/platform/cuda/cuda_runtime_include.h26
-rw-r--r--build/platform/cuda/ya.make208
2 files changed, 117 insertions, 117 deletions
diff --git a/build/platform/cuda/cuda_runtime_include.h b/build/platform/cuda/cuda_runtime_include.h
index 0acd501894..e60aacc4fb 100644
--- a/build/platform/cuda/cuda_runtime_include.h
+++ b/build/platform/cuda/cuda_runtime_include.h
@@ -1,13 +1,13 @@
-#pragma once
-
-// Компилятор nvcc из CUDA Toolkit при компиляции файла включает неявную зависимость
-// $CUDA_ROOT/include/cuda_runtime.h, которая в свою очередь включает другие файлы
-// из $CUDA_ROOT, а так же из стандартной библиотеки C++. Файлы из внешних ресурсов
-// не доступны на этапе конфигурирования сборки, и зависимости из них не учитываются.
-// Это, в частности, приводит к поломке сборки с использованием nvcc в режиме sandboxing-а.
-
-// Здесь перечислены такие зависимости. Этот файл добавляется в качестве дополнительной
-// зависимости к каждой компиляции nvcc.
-
-#include <cmath>
-#include <new>
+#pragma once
+
+// Компилятор nvcc из CUDA Toolkit при компиляции файла включает неявную зависимость
+// $CUDA_ROOT/include/cuda_runtime.h, которая в свою очередь включает другие файлы
+// из $CUDA_ROOT, а так же из стандартной библиотеки C++. Файлы из внешних ресурсов
+// не доступны на этапе конфигурирования сборки, и зависимости из них не учитываются.
+// Это, в частности, приводит к поломке сборки с использованием nvcc в режиме sandboxing-а.
+
+// Здесь перечислены такие зависимости. Этот файл добавляется в качестве дополнительной
+// зависимости к каждой компиляции nvcc.
+
+#include <cmath>
+#include <new>
diff --git a/build/platform/cuda/ya.make b/build/platform/cuda/ya.make
index 5f3c896c47..3615f682cd 100644
--- a/build/platform/cuda/ya.make
+++ b/build/platform/cuda/ya.make
@@ -1,16 +1,16 @@
-RESOURCES_LIBRARY()
-
-# https://wiki.yandex-team.ru/devtools/cuda/
-
-OWNER(g:contrib somov)
-
-IF (NOT HAVE_CUDA)
- MESSAGE(FATAL_ERROR "No CUDA Toolkit for your build")
-ENDIF()
-
-IF (USE_ARCADIA_CUDA)
- IF (HOST_OS_LINUX AND HOST_ARCH_X86_64)
- IF (OS_LINUX AND ARCH_X86_64)
+RESOURCES_LIBRARY()
+
+# https://wiki.yandex-team.ru/devtools/cuda/
+
+OWNER(g:contrib somov)
+
+IF (NOT HAVE_CUDA)
+ MESSAGE(FATAL_ERROR "No CUDA Toolkit for your build")
+ENDIF()
+
+IF (USE_ARCADIA_CUDA)
+ IF (HOST_OS_LINUX AND HOST_ARCH_X86_64)
+ IF (OS_LINUX AND ARCH_X86_64)
IF (CUDA_VERSION == "11.4")
DECLARE_EXTERNAL_RESOURCE(CUDA sbr:2410761119) # CUDA Toolkit 11.4.2 for Linux x86-64
ELSEIF (CUDA_VERSION == "11.3")
@@ -20,12 +20,12 @@ IF (USE_ARCADIA_CUDA)
ELSEIF (CUDA_VERSION == "11.1")
DECLARE_EXTERNAL_RESOURCE(CUDA sbr:1882836946) # CUDA Toolkit 11.1.1 for Linux x86-64
ELSEIF (CUDA_VERSION == "11.0")
- DECLARE_EXTERNAL_RESOURCE(CUDA sbr:1647896014) # CUDA Toolkit 11.0.2 for Linux x86-64
+ DECLARE_EXTERNAL_RESOURCE(CUDA sbr:1647896014) # CUDA Toolkit 11.0.2 for Linux x86-64
ELSEIF (CUDA_VERSION == "10.1")
DECLARE_EXTERNAL_RESOURCE(CUDA sbr:2077988857) # CUDA Toolkit 10.1.168 for Linux x86-64
- ELSE()
- ENABLE(CUDA_NOT_FOUND)
- ENDIF()
+ ELSE()
+ ENABLE(CUDA_NOT_FOUND)
+ ENDIF()
ELSEIF(OS_LINUX AND ARCH_AARCH64)
IF (CUDA_VERSION == "11.3")
DECLARE_EXTERNAL_RESOURCE(CUDA sbr:2227720086) # CUDA Toolkit 11.3.20210513 (11.3.1) for Linux x86-64 with linux-aarch64 support
@@ -34,10 +34,10 @@ IF (USE_ARCADIA_CUDA)
ELSE()
ENABLE(CUDA_NOT_FOUND)
ENDIF()
- ELSE()
- ENABLE(CUDA_NOT_FOUND)
- ENDIF()
-
+ ELSE()
+ ENABLE(CUDA_NOT_FOUND)
+ ENDIF()
+
ELSEIF (HOST_OS_LINUX AND HOST_ARCH_PPC64LE)
IF (OS_LINUX AND ARCH_PPC64LE)
IF (CUDA_VERSION == "10.1")
@@ -50,51 +50,51 @@ IF (USE_ARCADIA_CUDA)
ENABLE(CUDA_NOT_FOUND)
ENDIF()
- ELSEIF (HOST_OS_DARWIN AND HOST_ARCH_X86_64)
- IF (OS_DARWIN AND ARCH_X86_64)
+ ELSEIF (HOST_OS_DARWIN AND HOST_ARCH_X86_64)
+ IF (OS_DARWIN AND ARCH_X86_64)
IF (CUDA_VERSION == "10.1")
- DECLARE_EXTERNAL_RESOURCE(CUDA sbr:978727023) # CUDA Toolkit 10.1.168 for macOS x86-64
- ENDIF()
-
- ELSE()
- ENABLE(CUDA_NOT_FOUND)
- ENDIF()
-
- ELSEIF (HOST_OS_WINDOWS AND HOST_ARCH_X86_64)
- IF (OS_WINDOWS AND ARCH_X86_64)
+ DECLARE_EXTERNAL_RESOURCE(CUDA sbr:978727023) # CUDA Toolkit 10.1.168 for macOS x86-64
+ ENDIF()
+
+ ELSE()
+ ENABLE(CUDA_NOT_FOUND)
+ ENDIF()
+
+ ELSEIF (HOST_OS_WINDOWS AND HOST_ARCH_X86_64)
+ IF (OS_WINDOWS AND ARCH_X86_64)
IF (CUDA_VERSION == "11.3")
DECLARE_EXTERNAL_RESOURCE(CUDA sbr:2215101513) # CUDA Toolkit 11.3.1 for Windows x86-64
ELSEIF (CUDA_VERSION == "11.1")
DECLARE_EXTERNAL_RESOURCE(CUDA sbr:1896564605) # CUDA Toolkit 11.1.1 for Windows x86-64
ELSEIF (CUDA_VERSION == "10.1")
- DECLARE_EXTERNAL_RESOURCE(CUDA sbr:978734165) # CUDA Toolkit 10.1.168 for Windows x86-64
- ELSE()
- ENABLE(CUDA_NOT_FOUND)
- ENDIF()
-
- ELSE()
- ENABLE(CUDA_NOT_FOUND)
- ENDIF()
-
- ELSE()
- ENABLE(CUDA_NOT_FOUND)
- ENDIF()
-ENDIF()
-
-IF (USE_ARCADIA_CUDA_HOST_COMPILER)
- IF (HOST_OS_LINUX AND HOST_ARCH_X86_64)
- IF (OS_LINUX AND ARCH_X86_64)
+ DECLARE_EXTERNAL_RESOURCE(CUDA sbr:978734165) # CUDA Toolkit 10.1.168 for Windows x86-64
+ ELSE()
+ ENABLE(CUDA_NOT_FOUND)
+ ENDIF()
+
+ ELSE()
+ ENABLE(CUDA_NOT_FOUND)
+ ENDIF()
+
+ ELSE()
+ ENABLE(CUDA_NOT_FOUND)
+ ENDIF()
+ENDIF()
+
+IF (USE_ARCADIA_CUDA_HOST_COMPILER)
+ IF (HOST_OS_LINUX AND HOST_ARCH_X86_64)
+ IF (OS_LINUX AND ARCH_X86_64)
DECLARE_EXTERNAL_RESOURCE(CUDA_HOST_TOOLCHAIN sbr:1886578148) # Clang 11.0.0 for linux-x86_64
IF (CUDA_VERSION VERSION_LT "11.2")
# Equivalent to nvcc -allow-unsupported-compiler (present since 11.0).
CFLAGS(GLOBAL "-D__NV_NO_HOST_COMPILER_CHECK")
- ENDIF()
+ ENDIF()
ELSEIF(OS_LINUX AND ARCH_AARCH64)
DECLARE_EXTERNAL_RESOURCE(CUDA_HOST_TOOLCHAIN sbr:1886578148) # Clang 11.0.0 for linux-x86_64
- ELSE()
- ENABLE(CUDA_HOST_COMPILER_NOT_FOUND)
- ENDIF()
-
+ ELSE()
+ ENABLE(CUDA_HOST_COMPILER_NOT_FOUND)
+ ENDIF()
+
ELSEIF (HOST_OS_LINUX AND HOST_ARCH_PPC64LE)
IF (OS_LINUX AND ARCH_PPC64LE)
IF (CUDA_VERSION == "10.1")
@@ -107,51 +107,51 @@ IF (USE_ARCADIA_CUDA_HOST_COMPILER)
ENABLE(CUDA_HOST_COMPILER_NOT_FOUND)
ENDIF()
- ELSEIF (HOST_OS_DARWIN AND HOST_ARCH_X86_64)
- IF (OS_DARWIN AND ARCH_X86_64)
+ ELSEIF (HOST_OS_DARWIN AND HOST_ARCH_X86_64)
+ IF (OS_DARWIN AND ARCH_X86_64)
SET(__XCODE_RESOURCE_NAME CUDA_HOST_TOOLCHAIN)
IF (CUDA_VERSION == "10.1")
- SET(__XCODE_TOOLCHAIN_VERSION "9.2") # (not latest)
+ SET(__XCODE_TOOLCHAIN_VERSION "9.2") # (not latest)
ELSE()
SET(__XCODE_TOOLCHAIN_VERSION "")
ENABLE(CUDA_HOST_COMPILER_NOT_FOUND)
- ENDIF()
+ ENDIF()
IF (__XCODE_TOOLCHAIN_VERSION)
INCLUDE(${ARCADIA_ROOT}/build/platform/xcode/ya.make.inc)
ENDIF()
- ELSE()
- ENABLE(CUDA_HOST_COMPILER_NOT_FOUND)
- ENDIF()
-
- ELSEIF (HOST_OS_WINDOWS AND HOST_ARCH_X86_64)
- IF (OS_WINDOWS AND ARCH_X86_64)
+ ELSE()
+ ENABLE(CUDA_HOST_COMPILER_NOT_FOUND)
+ ENDIF()
+
+ ELSEIF (HOST_OS_WINDOWS AND HOST_ARCH_X86_64)
+ IF (OS_WINDOWS AND ARCH_X86_64)
# To create this toolchain, install MSVS on Windows and run:
# devtools/tools_build/pack_sdk.py msvc out.tar
# Note: it will contain patched "VC/Auxiliary/Build/vcvarsall.bat"
# to prevent "nvcc fatal : Host compiler targets unsupported OS."
IF (CUDA_HOST_MSVC_VERSION == "14.28.29910")
DECLARE_EXTERNAL_RESOURCE(CUDA_HOST_TOOLCHAIN sbr:2153212401)
- ELSE()
- MESSAGE(FATAL_ERROR "Unexpected or unspecified Microsoft Visual C++ CUDA host compiler version")
- ENDIF()
-
- ELSE()
- ENABLE(CUDA_HOST_COMPILER_NOT_FOUND)
- ENDIF()
-
- ELSE()
- ENABLE(CUDA_HOST_COMPILER_NOT_FOUND)
- ENDIF()
-ENDIF()
-
-IF (CUDA_NOT_FOUND)
- MESSAGE(FATAL_ERROR "No CUDA Toolkit for the selected platform")
-ENDIF()
-
-IF (CUDA_HOST_COMPILER_NOT_FOUND)
- MESSAGE(FATAL_ERROR "No CUDA host compiler for the selected platform and CUDA Toolkit version ${CUDA_VERSION}")
-ENDIF()
-
+ ELSE()
+ MESSAGE(FATAL_ERROR "Unexpected or unspecified Microsoft Visual C++ CUDA host compiler version")
+ ENDIF()
+
+ ELSE()
+ ENABLE(CUDA_HOST_COMPILER_NOT_FOUND)
+ ENDIF()
+
+ ELSE()
+ ENABLE(CUDA_HOST_COMPILER_NOT_FOUND)
+ ENDIF()
+ENDIF()
+
+IF (CUDA_NOT_FOUND)
+ MESSAGE(FATAL_ERROR "No CUDA Toolkit for the selected platform")
+ENDIF()
+
+IF (CUDA_HOST_COMPILER_NOT_FOUND)
+ MESSAGE(FATAL_ERROR "No CUDA host compiler for the selected platform and CUDA Toolkit version ${CUDA_VERSION}")
+ENDIF()
+
# Use thrust and cub from Arcadia, not from HPC SDK
# NB:
# it would be better to use PEERDIR instead,
@@ -161,22 +161,22 @@ ADDINCL(
GLOBAL contrib/libs/nvidia/cub
)
-IF (HOST_OS_WINDOWS)
- SET_APPEND_WITH_GLOBAL(USER_CFLAGS GLOBAL "\"-I${CUDA_ROOT}/include\"")
-ELSE()
- CFLAGS(GLOBAL "-I${CUDA_ROOT}/include")
-ENDIF()
-
-IF (HOST_OS_WINDOWS)
- SET_APPEND(LDFLAGS_GLOBAL "\"/LIBPATH:${CUDA_ROOT}/lib/x64\"")
+IF (HOST_OS_WINDOWS)
+ SET_APPEND_WITH_GLOBAL(USER_CFLAGS GLOBAL "\"-I${CUDA_ROOT}/include\"")
+ELSE()
+ CFLAGS(GLOBAL "-I${CUDA_ROOT}/include")
+ENDIF()
+
+IF (HOST_OS_WINDOWS)
+ SET_APPEND(LDFLAGS_GLOBAL "\"/LIBPATH:${CUDA_ROOT}/lib/x64\"")
ELSEIF(HOST_OS_LINUX AND OS_LINUX AND ARCH_AARCH64)
LDFLAGS("-L${CUDA_ROOT}/targets/sbsa-linux/lib")
-ELSEIF(HOST_OS_LINUX)
- LDFLAGS("-L${CUDA_ROOT}/lib64")
-ELSE()
- LDFLAGS("-L${CUDA_ROOT}/lib")
-ENDIF()
-
+ELSEIF(HOST_OS_LINUX)
+ LDFLAGS("-L${CUDA_ROOT}/lib64")
+ELSE()
+ LDFLAGS("-L${CUDA_ROOT}/lib")
+ENDIF()
+
IF (CUDA_REQUIRED)
IF(HOST_OS_LINUX)
LDFLAGS("-L${CUDA_ROOT}/lib64/stubs")
@@ -186,10 +186,10 @@ IF (CUDA_REQUIRED)
ENDIF()
ENDIF()
-IF (HOST_OS_WINDOWS)
+IF (HOST_OS_WINDOWS)
LDFLAGS(cudadevrt.lib cudart_static.lib)
-ELSE()
+ELSE()
EXTRALIBS(-lcudadevrt -lcudart_static -lculibos)
-ENDIF()
-
-END()
+ENDIF()
+
+END()