mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-11-06 04:18:00 +00:00
Fixing llvm-shlib's LLVM_DYLIB_EXPORT_ALL to work with Darwin fat binaries.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@235114 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -55,37 +55,37 @@ if(NOT DEFINED LLVM_DYLIB_EXPORTED_SYMBOL_FILE)
|
|||||||
|
|
||||||
set(LLVM_EXPORTED_SYMBOL_FILE ${CMAKE_BINARY_DIR}/libllvm.exports)
|
set(LLVM_EXPORTED_SYMBOL_FILE ${CMAKE_BINARY_DIR}/libllvm.exports)
|
||||||
|
|
||||||
|
if (NOT LLVM_DYLIB_EXPORT_ALL)
|
||||||
foreach (lib ${LIB_NAMES})
|
foreach (lib ${LIB_NAMES})
|
||||||
|
|
||||||
set(LIB_DIR ${CMAKE_BINARY_DIR}/${CMAKE_CFG_INTDIR}/lib${LLVM_LIBDIR_SUFFIX})
|
set(LIB_DIR ${CMAKE_BINARY_DIR}/${CMAKE_CFG_INTDIR}/lib${LLVM_LIBDIR_SUFFIX})
|
||||||
set(LIB_NAME ${LIB_DIR}/${CMAKE_STATIC_LIBRARY_PREFIX}${lib})
|
set(LIB_NAME ${LIB_DIR}/${CMAKE_STATIC_LIBRARY_PREFIX}${lib})
|
||||||
set(LIB_PATH ${LIB_NAME}${CMAKE_STATIC_LIBRARY_SUFFIX})
|
set(LIB_PATH ${LIB_NAME}${CMAKE_STATIC_LIBRARY_SUFFIX})
|
||||||
set(LIB_EXPORTS_PATH ${LIB_NAME}.exports)
|
set(LIB_EXPORTS_PATH ${LIB_NAME}.exports)
|
||||||
|
|
||||||
list(APPEND LLVM_DYLIB_REQUIRED_EXPORTS ${LIB_EXPORTS_PATH})
|
list(APPEND LLVM_DYLIB_REQUIRED_EXPORTS ${LIB_EXPORTS_PATH})
|
||||||
|
|
||||||
if (LLVM_DYLIB_EXPORT_ALL)
|
|
||||||
add_custom_command(OUTPUT ${LIB_EXPORTS_PATH}
|
|
||||||
COMMAND nm ${LIB_PATH} | awk "/T / { print $3 }" | sort -u | sed -e "s/^_//g" > ${LIB_EXPORTS_PATH}
|
|
||||||
WORKING_DIRECTORY ${LIB_DIR}
|
|
||||||
DEPENDS ${lib}
|
|
||||||
COMMENT "Generating Export list for ${lib}..."
|
|
||||||
VERBATIM )
|
|
||||||
else()
|
|
||||||
add_custom_command(OUTPUT ${LIB_EXPORTS_PATH}
|
add_custom_command(OUTPUT ${LIB_EXPORTS_PATH}
|
||||||
COMMAND nm ${LIB_PATH} | awk "/T _LLVM/ || /T LLVM/ { print $3 }" | sort -u | sed -e "s/^_//g" > ${LIB_EXPORTS_PATH}
|
COMMAND nm ${LIB_PATH} | awk "/T _LLVM/ || /T LLVM/ { print $3 }" | sort -u | sed -e "s/^_//g" > ${LIB_EXPORTS_PATH}
|
||||||
WORKING_DIRECTORY ${LIB_DIR}
|
WORKING_DIRECTORY ${LIB_DIR}
|
||||||
DEPENDS ${lib}
|
DEPENDS ${lib}
|
||||||
COMMENT "Generating Export list for ${lib}..."
|
COMMENT "Generating Export list for ${lib}..."
|
||||||
VERBATIM )
|
VERBATIM )
|
||||||
endif()
|
|
||||||
endforeach ()
|
endforeach ()
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if (LLVM_DYLIB_EXPORT_ALL)
|
||||||
|
add_custom_command(OUTPUT ${LLVM_EXPORTED_SYMBOL_FILE}
|
||||||
|
COMMAND echo "LLVM*" > ${LLVM_EXPORTED_SYMBOL_FILE} && echo "_ZN4llvm*" >> ${LLVM_EXPORTED_SYMBOL_FILE}
|
||||||
|
WORKING_DIRECTORY ${LIB_DIR}
|
||||||
|
DEPENDS ${LLVM_DYLIB_REQUIRED_EXPORTS}
|
||||||
|
COMMENT "Generating combined export list...")
|
||||||
|
else()
|
||||||
add_custom_command(OUTPUT ${LLVM_EXPORTED_SYMBOL_FILE}
|
add_custom_command(OUTPUT ${LLVM_EXPORTED_SYMBOL_FILE}
|
||||||
COMMAND cat ${LLVM_DYLIB_REQUIRED_EXPORTS} > ${LLVM_EXPORTED_SYMBOL_FILE}
|
COMMAND cat ${LLVM_DYLIB_REQUIRED_EXPORTS} > ${LLVM_EXPORTED_SYMBOL_FILE}
|
||||||
WORKING_DIRECTORY ${LIB_DIR}
|
WORKING_DIRECTORY ${LIB_DIR}
|
||||||
DEPENDS ${LLVM_DYLIB_REQUIRED_EXPORTS}
|
DEPENDS ${LLVM_DYLIB_REQUIRED_EXPORTS}
|
||||||
COMMENT "Generating combined export list...")
|
COMMENT "Generating combined export list...")
|
||||||
|
endif()
|
||||||
|
|
||||||
add_custom_target(libLLVMExports DEPENDS ${LLVM_EXPORTED_SYMBOL_FILE})
|
add_custom_target(libLLVMExports DEPENDS ${LLVM_EXPORTED_SYMBOL_FILE})
|
||||||
else()
|
else()
|
||||||
@@ -95,10 +95,12 @@ endif()
|
|||||||
|
|
||||||
add_llvm_library(LLVM SHARED ${SOURCES})
|
add_llvm_library(LLVM SHARED ${SOURCES})
|
||||||
|
|
||||||
|
list(REMOVE_DUPLICATES LIB_NAMES)
|
||||||
if("${CMAKE_SYSTEM_NAME}" STREQUAL "Linux") # FIXME: It should be "GNU ld for elf"
|
if("${CMAKE_SYSTEM_NAME}" STREQUAL "Linux") # FIXME: It should be "GNU ld for elf"
|
||||||
# GNU ld doesn't resolve symbols in the version script.
|
# GNU ld doesn't resolve symbols in the version script.
|
||||||
list(REMOVE_DUPLICATES LIB_NAMES)
|
|
||||||
set(LIB_NAMES -Wl,--whole-archive ${LIB_NAMES} -Wl,--no-whole-archive)
|
set(LIB_NAMES -Wl,--whole-archive ${LIB_NAMES} -Wl,--no-whole-archive)
|
||||||
|
elseif("${CMAKE_SYSTEM_NAME}" STREQUAL "Darwin")
|
||||||
|
set(LIB_NAMES -Wl,-all_load ${LIB_NAMES})
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
target_link_libraries(LLVM PRIVATE ${LIB_NAMES})
|
target_link_libraries(LLVM PRIVATE ${LIB_NAMES})
|
||||||
|
|||||||
Reference in New Issue
Block a user