[flang] Fix multi-config generator builds.

Summary:
Currently the binaries are output directly into the bin subdirectory of the
build directory. This doesn't work correctly with multi-config generators which
should output the binaries into <CONFIG_NAME>/bin instead.

Reviewers: sscalpone, richard.barton.arm

Subscribers: mgorny, llvm-commits

Tags: #llvm

Differential Revision: https://reviews.llvm.org/D84022
This commit is contained in:
David Truby 2020-07-16 16:13:09 +01:00
parent 1ac72a0774
commit 332170356e
4 changed files with 10 additions and 13 deletions

View File

@ -180,7 +180,7 @@ else()
${LLVM_INCLUDE_TESTS}) ${LLVM_INCLUDE_TESTS})
set(FLANG_GTEST_AVAIL 1) set(FLANG_GTEST_AVAIL 1)
set(FLANG_BINARY_DIR ${CMAKE_BINARY_DIR}/tools/flang) set(FLANG_BINARY_DIR ${CMAKE_CURRENT_BINARY_DIR})
set(BACKEND_PACKAGE_STRING "${PACKAGE_STRING}") set(BACKEND_PACKAGE_STRING "${PACKAGE_STRING}")
if (LINK_WITH_FIR) if (LINK_WITH_FIR)
set(MLIR_MAIN_SRC_DIR ${LLVM_MAIN_SRC_DIR}/../mlir/include ) # --src-root set(MLIR_MAIN_SRC_DIR ${LLVM_MAIN_SRC_DIR}/../mlir/include ) # --src-root
@ -194,8 +194,6 @@ endif()
if(LINK_WITH_FIR) if(LINK_WITH_FIR)
# tco tool and FIR lib output directories # tco tool and FIR lib output directories
set(LLVM_RUNTIME_OUTPUT_INTDIR ${CMAKE_BINARY_DIR}/bin)
set(LLVM_LIBRARY_OUTPUT_INTDIR ${CMAKE_BINARY_DIR}/lib)
# Always build tco tool # Always build tco tool
set(LLVM_BUILD_TOOLS ON) set(LLVM_BUILD_TOOLS ON)
message(STATUS "Linking driver with FIR and LLVM") message(STATUS "Linking driver with FIR and LLVM")

View File

@ -48,12 +48,6 @@ config.test_exec_root = os.path.join(config.flang_obj_root, 'test')
llvm_config.with_environment('PATH', config.flang_tools_dir, append_path=True) llvm_config.with_environment('PATH', config.flang_tools_dir, append_path=True)
llvm_config.with_environment('PATH', config.llvm_tools_dir, append_path=True) llvm_config.with_environment('PATH', config.llvm_tools_dir, append_path=True)
# For builds with FIR, set path for tco and enable related tests
if config.flang_llvm_tools_dir != "" :
config.available_features.add('fir')
if config.llvm_tools_dir != config.flang_llvm_tools_dir :
llvm_config.with_environment('PATH', config.flang_llvm_tools_dir, append_path=True)
# For each occurrence of a flang tool name, replace it with the full path to # For each occurrence of a flang tool name, replace it with the full path to
# the build directory holding that tool. # the build directory holding that tool.
tools = [ tools = [
@ -61,7 +55,7 @@ tools = [
extra_args=["-intrinsic-module-directory "+config.flang_intrinsic_modules_dir], extra_args=["-intrinsic-module-directory "+config.flang_intrinsic_modules_dir],
unresolved='fatal') unresolved='fatal')
] ]
llvm_config.add_tool_substitutions(tools, [config.flang_llvm_tools_dir]) llvm_config.add_tool_substitutions(tools, config.llvm_tools_dir)
# Enable libpgmath testing # Enable libpgmath testing
result = lit_config.params.get("LIBPGMATH") result = lit_config.params.get("LIBPGMATH")

View File

@ -7,7 +7,6 @@ config.flang_obj_root = "@FLANG_BINARY_DIR@"
config.flang_src_dir = "@FLANG_SOURCE_DIR@" config.flang_src_dir = "@FLANG_SOURCE_DIR@"
config.flang_tools_dir = "@FLANG_TOOLS_DIR@" config.flang_tools_dir = "@FLANG_TOOLS_DIR@"
config.flang_intrinsic_modules_dir = "@FLANG_INTRINSIC_MODULES_DIR@" config.flang_intrinsic_modules_dir = "@FLANG_INTRINSIC_MODULES_DIR@"
config.flang_llvm_tools_dir = "@CMAKE_BINARY_DIR@/bin"
config.python_executable = "@PYTHON_EXECUTABLE@" config.python_executable = "@PYTHON_EXECUTABLE@"
# Support substitution of the tools_dir with user parameters. This is # Support substitution of the tools_dir with user parameters. This is

View File

@ -59,8 +59,14 @@ add_custom_target(module_files ALL DEPENDS ${MODULE_FILES})
install(TARGETS f18 DESTINATION bin) install(TARGETS f18 DESTINATION bin)
set(FLANG_INTRINSIC_MODULES_DIR ${FLANG_BINARY_DIR}/include/flang) set(FLANG_INTRINSIC_MODULES_DIR ${FLANG_BINARY_DIR}/include/flang)
configure_file(${CMAKE_CURRENT_SOURCE_DIR}/flang.sh.in ${CMAKE_BINARY_DIR}/tools/flang/bin/flang @ONLY) # This flang shell script will only work in a POSIX shell.
file(COPY ${CMAKE_BINARY_DIR}/tools/flang/bin/flang DESTINATION ${CMAKE_BINARY_DIR}/bin FILE_PERMISSIONS OWNER_EXECUTE OWNER_READ OWNER_WRITE) if (NOT WIN32)
configure_file(${CMAKE_CURRENT_SOURCE_DIR}/flang.sh.in ${CMAKE_CURRENT_BINARY_DIR}/tools/flang/bin/flang @ONLY)
add_custom_command(TARGET f18
POST_BUILD
COMMAND ${CMAKE_COMMAND} -E copy ${CMAKE_CURRENT_BINARY_DIR}/tools/flang/bin/flang ${LLVM_RUNTIME_OUTPUT_INTDIR}/flang
COMMAND chmod +x ${LLVM_RUNTIME_OUTPUT_INTDIR}/flang)
endif()
# The flang script to be installed needs a different path to the headers. # The flang script to be installed needs a different path to the headers.
set(FLANG_INTRINSIC_MODULES_DIR ${CMAKE_INSTALL_PREFIX}/include/flang) set(FLANG_INTRINSIC_MODULES_DIR ${CMAKE_INSTALL_PREFIX}/include/flang)
configure_file(${CMAKE_CURRENT_SOURCE_DIR}/flang.sh.in ${FLANG_BINARY_DIR}/bin/flang-install.sh @ONLY) configure_file(${CMAKE_CURRENT_SOURCE_DIR}/flang.sh.in ${FLANG_BINARY_DIR}/bin/flang-install.sh @ONLY)