cmake_minimum_required(VERSION 3.8) project (ExportPTX CUDA) #Goal for this example: # How to generate PTX files instead of OBJECT files # How to reference PTX files for custom commands # How to install PTX files add_library(CudaPTX OBJECT kernelA.cu kernelB.cu) set_property(TARGET CudaPTX PROPERTY CUDA_PTX_COMPILATION ON) #Test ObjectFiles with file(GENERATE) file(GENERATE OUTPUT ${CMAKE_CURRENT_BINARY_DIR}/gen_$/>path_to_objs.h CONTENT [[ #include #include #ifndef path_to_objs #define path_to_objs static std::string ptx_paths = "$"; #endif ]] ) #We are going to need a wrapper around bin2c for multiple reasons # 1. bin2c only converts a single file at a time # 2. bin2c has only standard out support, so we have to manually # redirect to a cmake buffer # 3. We want to pack everything into a single output file, so we # need to also pass the --name option set(output_file ${CMAKE_CURRENT_BINARY_DIR}/embedded_objs.h) find_package(CUDAToolkit REQUIRED) find_program(bin_to_c NAMES bin2c PATHS ${CUDAToolkit_BIN_DIR} ) if(NOT bin_to_c) message(FATAL_ERROR "bin2c not found:\n" " CUDAToolkit_BIN_DIR='${CUDAToolkit_BIN_DIR}'\n" ) endif() add_custom_command( OUTPUT "${output_file}" COMMAND ${CMAKE_COMMAND} "-DBIN_TO_C_COMMAND=${bin_to_c}" "-DOBJECTS=$" "-DOUTPUT=${output_file}" -P ${CMAKE_CURRENT_SOURCE_DIR}/bin2c_wrapper.cmake VERBATIM DEPENDS $ COMMENT "Converting Object files to a C header" ) add_executable(CudaOnlyExportPTX main.cu ${output_file}) add_dependencies(CudaOnlyExportPTX CudaPTX) target_include_directories(CudaOnlyExportPTX PRIVATE ${CMAKE_CURRENT_BINARY_DIR} ) target_compile_definitions(CudaOnlyExportPTX PRIVATE "CONFIG_TYPE=gen_$>") if(APPLE) # Help the static cuda runtime find the driver (libcuda.dyllib) at runtime. set_property(TARGET CudaOnlyExportPTX PROPERTY BUILD_RPATH ${CMAKE_CUDA_IMPLICIT_LINK_DIRECTORIES}) endif() #Verify that we can install object targets properly install(TARGETS CudaPTX CudaOnlyExportPTX EXPORT cudaPTX RUNTIME DESTINATION bin LIBRARY DESTINATION lib OBJECTS DESTINATION objs ) install(EXPORT cudaPTX DESTINATION lib/cudaPTX)