Index: libunwind/CMakeLists.txt =================================================================== --- libunwind/CMakeLists.txt +++ libunwind/CMakeLists.txt @@ -78,6 +78,7 @@ option(LIBUNWIND_IS_BAREMETAL "Build libunwind for baremetal targets." OFF) option(LIBUNWIND_USE_FRAME_HEADER_CACHE "Cache frame headers for unwinding. Requires locking dl_iterate_phdr." OFF) option(LIBUNWIND_REMEMBER_HEAP_ALLOC "Use heap instead of the stack for .cfi_remember_state." OFF) +option(LIBUNWIND_INSTALL_HEADERS "Install the libunwind headers." OFF) set(LIBUNWIND_LIBDIR_SUFFIX "${LLVM_LIBDIR_SUFFIX}" CACHE STRING "Define suffix of library directory name (32/64)") @@ -372,7 +373,7 @@ # Setup Source Code #=============================================================================== -include_directories(include) +add_subdirectory(include) add_subdirectory(src) Index: libunwind/include/CMakeLists.txt =================================================================== --- /dev/null +++ libunwind/include/CMakeLists.txt @@ -0,0 +1,38 @@ +set(files + __libunwind_config.h + libunwind.h + unwind_arm_ehabi.h + unwind_itanium.h + unwind.h + ) + +add_library(unwind-headers INTERFACE) +target_include_directories(unwind-headers INTERFACE ${CMAKE_CURRENT_SOURCE_DIR}) + +install(FILES ${files} + DESTINATION include + COMPONENT unwind-headers + PERMISSIONS OWNER_READ OWNER_WRITE GROUP_READ WORLD_READ +) + +if(APPLE) + install(FILES mach-o/compact_unwind_encoding.h + DESTINATION include/mach-o + COMPONENT unwind-headers + PERMISSIONS OWNER_READ OWNER_WRITE GROUP_READ WORLD_READ + ) +endif() + +if(NOT CMAKE_CONFIGURATION_TYPES AND LIBUNWIND_INSTALL_HEADERS) + add_custom_target(install-unwind-headers + DEPENDS unwind-headers + COMMAND "${CMAKE_COMMAND}" + -DCMAKE_INSTALL_COMPONENT=unwind-headers + -P "${LIBUNWIND_BINARY_DIR}/cmake_install.cmake") + add_custom_target(install-unwind-headers-stripped + DEPENDS unwind-headers + COMMAND "${CMAKE_COMMAND}" + -DCMAKE_INSTALL_COMPONENT=unwind-headers + -DCMAKE_INSTALL_DO_STRIP=1 + -P "${LIBUNWIND_BINARY_DIR}/cmake_install.cmake") +endif() Index: libunwind/src/CMakeLists.txt =================================================================== --- libunwind/src/CMakeLists.txt +++ libunwind/src/CMakeLists.txt @@ -133,7 +133,8 @@ else() target_compile_options(unwind_shared PRIVATE -fno-rtti) endif() - target_link_libraries(unwind_shared PRIVATE ${LIBUNWIND_LIBRARIES}) + target_link_libraries(unwind_shared PRIVATE ${LIBUNWIND_LIBRARIES} + PRIVATE unwind-headers) set_target_properties(unwind_shared PROPERTIES CXX_EXTENSIONS OFF @@ -160,7 +161,8 @@ else() target_compile_options(unwind_static PRIVATE -fno-rtti) endif() - target_link_libraries(unwind_static PRIVATE ${LIBUNWIND_LIBRARIES}) + target_link_libraries(unwind_static PRIVATE ${LIBUNWIND_LIBRARIES} + PRIVATE unwind-headers) set_target_properties(unwind_static PROPERTIES CXX_EXTENSIONS OFF @@ -207,4 +209,8 @@ -DCMAKE_INSTALL_COMPONENT=unwind -DCMAKE_INSTALL_DO_STRIP=1 -P "${LIBUNWIND_BINARY_DIR}/cmake_install.cmake") + if(LIBUNWIND_INSTALL_HEADERS) + add_dependencies(install-unwind install-unwind-headers) + add_dependencies(install-unwind-stripped install-unwind-headers-stripped) + endif() endif()