[Openmp-commits] [PATCH] D94573: [OpenMP] Drop the static library libomptarget-nvptx
Shilei Tian via Phabricator via Openmp-commits
openmp-commits at lists.llvm.org
Thu Jan 14 09:39:03 PST 2021
tianshilei1992 updated this revision to Diff 316686.
tianshilei1992 added a comment.
Rebased the patch and removed unnecessary part
Repository:
rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D94573/new/
https://reviews.llvm.org/D94573
Files:
openmp/libomptarget/deviceRTLs/nvptx/CMakeLists.txt
Index: openmp/libomptarget/deviceRTLs/nvptx/CMakeLists.txt
===================================================================
--- openmp/libomptarget/deviceRTLs/nvptx/CMakeLists.txt
+++ openmp/libomptarget/deviceRTLs/nvptx/CMakeLists.txt
@@ -10,31 +10,6 @@
#
##===----------------------------------------------------------------------===##
-set(LIBOMPTARGET_NVPTX_ALTERNATE_HOST_COMPILER "" CACHE STRING
- "Path to alternate NVCC host compiler to be used by the NVPTX device RTL.")
-
-if(LIBOMPTARGET_NVPTX_ALTERNATE_HOST_COMPILER)
- find_program(ALTERNATE_CUDA_HOST_COMPILER NAMES ${LIBOMPTARGET_NVPTX_ALTERNATE_HOST_COMPILER})
- if(NOT ALTERNATE_CUDA_HOST_COMPILER)
- libomptarget_say("Not building CUDA offloading device RTL: invalid NVPTX alternate host compiler.")
- endif()
- set(CUDA_HOST_COMPILER ${ALTERNATE_CUDA_HOST_COMPILER} CACHE FILEPATH "" FORCE)
-endif()
-
-# We can't use clang as nvcc host preprocessor, so we attempt to replace it with
-# gcc.
-if(CUDA_HOST_COMPILER MATCHES clang)
-
- find_program(LIBOMPTARGET_NVPTX_ALTERNATE_GCC_HOST_COMPILER NAMES gcc)
-
- if(NOT LIBOMPTARGET_NVPTX_ALTERNATE_GCC_HOST_COMPILER)
- libomptarget_say("Not building CUDA offloading device RTL: clang is not supported as NVCC host compiler.")
- libomptarget_say("Please include gcc in your path or set LIBOMPTARGET_NVPTX_ALTERNATE_HOST_COMPILER to the full path of of valid compiler.")
- return()
- endif()
- set(CUDA_HOST_COMPILER "${LIBOMPTARGET_NVPTX_ALTERNATE_GCC_HOST_COMPILER}" CACHE FILEPATH "" FORCE)
-endif()
-
get_filename_component(devicertl_base_directory
${CMAKE_CURRENT_SOURCE_DIR}
DIRECTORY)
@@ -94,24 +69,6 @@
# Activate RTL message dumps if requested by the user.
set(LIBOMPTARGET_NVPTX_DEBUG FALSE CACHE BOOL
"Activate NVPTX device RTL debug messages.")
- if(${LIBOMPTARGET_NVPTX_DEBUG})
- set(CUDA_DEBUG -DOMPTARGET_NVPTX_DEBUG=-1 -g --ptxas-options=-v)
- endif()
-
- # NVPTX runtime library has to be statically linked. Dynamic linking is not
- # yet supported by the CUDA toolchain on the device.
- set(BUILD_SHARED_LIBS OFF)
- set(CUDA_SEPARABLE_COMPILATION ON)
- list(APPEND CUDA_NVCC_FLAGS -I${devicertl_base_directory}
- -I${devicertl_nvptx_directory}/src)
- cuda_add_library(omptarget-nvptx STATIC ${cuda_src_files}
- OPTIONS ${CUDA_ARCH} ${CUDA_DEBUG} ${MAX_SM_DEFINITION})
-
- # Install device RTL under the lib destination folder.
- install(TARGETS omptarget-nvptx ARCHIVE DESTINATION "${OPENMP_INSTALL_LIBDIR}")
-
- target_link_libraries(omptarget-nvptx ${CUDA_LIBRARIES})
-
# Check if we can create an LLVM bitcode implementation of the runtime library
# that could be inlined in the user application. For that we need to find
@@ -195,7 +152,7 @@
# Copy library to destination.
add_custom_command(TARGET omptarget-nvptx-${sm}-bc POST_BUILD
COMMAND ${CMAKE_COMMAND} -E copy ${CMAKE_CURRENT_BINARY_DIR}/libomptarget-nvptx-sm_${sm}.bc
- $<TARGET_FILE_DIR:omptarget-nvptx>)
+ ${LIBOMPTARGET_LIBRARY_DIR})
# Install bitcode library under the lib destination folder.
install(FILES ${CMAKE_CURRENT_BINARY_DIR}/libomptarget-nvptx-sm_${sm}.bc DESTINATION "${OPENMP_INSTALL_LIBDIR}")
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D94573.316686.patch
Type: text/x-patch
Size: 3310 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/openmp-commits/attachments/20210114/a39d79ad/attachment.bin>
More information about the Openmp-commits
mailing list