blob: 1249220ca4fc9797c067cdec4ee5948ca6284612 [file] [log] [blame] [edit]
# Distributed under the OSI-approved BSD 3-Clause License. See accompanying
# file LICENSE.rst or https://cmake.org/licensing for details.
# Helper functions for chipStar (spirv platform) HIP support
# Set chipStar compile flags in CMAKE_HIP_COMPILE_OBJECT
function(_cmake_chipstar_set_compiler_flags)
if(NOT CMAKE_HIP_PLATFORM STREQUAL "spirv" OR NOT CMAKE_HIP_COMPILER_ID STREQUAL "Clang")
return()
endif()
set(_hip_path "${CMAKE_HIP_COMPILER_ROCM_ROOT}")
set(_chipstar_flags "--offload=spirv64 --hip-path=\"${_hip_path}\" -nogpulib -nohipwrapperinc -include \"${_hip_path}/include/hip/spirv_fixups.h\"")
set(CMAKE_HIP_COMPILE_OBJECT
"<CMAKE_HIP_COMPILER> ${_chipstar_flags} <DEFINES> <INCLUDES> <FLAGS> -o <OBJECT> -x hip -c <SOURCE>" PARENT_SCOPE)
endfunction()
# Set link commands for chipStar to include libCHIP.so
# This makes CMake treat it as if the compiler driver links it implicitly
function(_cmake_chipstar_set_link_commands)
if(NOT CMAKE_HIP_PLATFORM STREQUAL "spirv")
return()
endif()
set(_hip_path "${CMAKE_HIP_COMPILER_ROCM_ROOT}")
set(_chipstar_lib "${_hip_path}/lib/libCHIP.so")
# Set link command templates with libCHIP.so appended (quoted for paths with spaces)
set(CMAKE_HIP_LINK_EXECUTABLE
"<CMAKE_HIP_COMPILER> <FLAGS> <LINK_FLAGS> <OBJECTS> -o <TARGET> <LINK_LIBRARIES> \"${_chipstar_lib}\"" PARENT_SCOPE)
set(CMAKE_HIP_CREATE_SHARED_LIBRARY
"<CMAKE_HIP_COMPILER> <CMAKE_SHARED_LIBRARY_HIP_FLAGS> <LANGUAGE_COMPILE_FLAGS> <LINK_FLAGS> <SONAME_FLAG><TARGET_SONAME> -o <TARGET> <OBJECTS> <LINK_LIBRARIES> \"${_chipstar_lib}\"" PARENT_SCOPE)
set(CMAKE_HIP_CREATE_SHARED_MODULE
"<CMAKE_HIP_COMPILER> <CMAKE_SHARED_LIBRARY_HIP_FLAGS> <LANGUAGE_COMPILE_FLAGS> <LINK_FLAGS> <SONAME_FLAG><TARGET_SONAME> -o <TARGET> <OBJECTS> <LINK_LIBRARIES> \"${_chipstar_lib}\"" PARENT_SCOPE)
endfunction()
# Set compiler ID test flags for chipStar (called before CMAKE_HIP_COMPILER_ROCM_ROOT is set)
function(_cmake_chipstar_set_compiler_id_flags)
if(NOT CMAKE_HIP_PLATFORM STREQUAL "spirv")
return()
endif()
# At this point CMAKE_HIP_COMPILER_ROCM_ROOT isn't set yet, use HIP_PATH or hipconfig
set(_hip_path "$ENV{HIP_PATH}")
if(NOT IS_DIRECTORY "${_hip_path}")
execute_process(COMMAND hipconfig --rocmpath
OUTPUT_VARIABLE _hip_path OUTPUT_STRIP_TRAILING_WHITESPACE)
endif()
if(IS_DIRECTORY "${_hip_path}")
file(TO_CMAKE_PATH "${_hip_path}" _hip_path)
# All flags in one string so they're used together. -no-hip-rt prevents linking amdhip64.
list(APPEND CMAKE_HIP_COMPILER_ID_TEST_FLAGS_FIRST
"-v --offload=spirv64 --hip-path=\"${_hip_path}\" -nogpulib -nohipwrapperinc -no-hip-rt \"${_hip_path}/lib/libCHIP.so\" -include \"${_hip_path}/include/hip/spirv_fixups.h\"")
set(CMAKE_HIP_COMPILER_ID_TEST_FLAGS_FIRST "${CMAKE_HIP_COMPILER_ID_TEST_FLAGS_FIRST}" PARENT_SCOPE)
endif()
endfunction()