From c1596192fa85328fbc664333aee1ba9ef02ac58e Mon Sep 17 00:00:00 2001 From: Andrew Kaster Date: Thu, 5 Dec 2024 15:46:02 -0700 Subject: [PATCH] CMake: Add workaround for binutils+patchelf incompatability --- CMakeLists.txt | 4 +++- .../CMake/vcpkg/generate_vcpkg_toolchain_variables.cmake | 9 +++++++++ 2 files changed, 12 insertions(+), 1 deletion(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index ecea1b97769..f0ea4b55068 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -7,6 +7,9 @@ if (VCPKG_TARGET_ANDROID) include("UI/Android/vcpkg_android.cmake") endif() +# vcpkg flags depend on what linker we are using +include("Meta/CMake/use_linker.cmake") + # Pass additional information to vcpkg toolchain files if we are using vcpkg. if (CMAKE_TOOLCHAIN_FILE MATCHES "vcpkg.cmake$") set(CMAKE_PROJECT_ladybird_INCLUDE_BEFORE "Meta/CMake/vcpkg/generate_vcpkg_toolchain_variables.cmake") @@ -29,7 +32,6 @@ set(LADYBIRD_SOURCE_DIR "${CMAKE_CURRENT_SOURCE_DIR}") list(APPEND CMAKE_MODULE_PATH "${LADYBIRD_SOURCE_DIR}/Meta/CMake") include(UI/cmake/EnableLagom.cmake) -include(use_linker) include(lagom_options NO_POLICY_SCOPE) include(lagom_compile_options) diff --git a/Meta/CMake/vcpkg/generate_vcpkg_toolchain_variables.cmake b/Meta/CMake/vcpkg/generate_vcpkg_toolchain_variables.cmake index a43a4493d69..a4c25bb9c56 100644 --- a/Meta/CMake/vcpkg/generate_vcpkg_toolchain_variables.cmake +++ b/Meta/CMake/vcpkg/generate_vcpkg_toolchain_variables.cmake @@ -8,4 +8,13 @@ if (NOT "${CMAKE_CXX_COMPILER}" STREQUAL "") string(APPEND EXTRA_VCPKG_VARIABLES "set(ENV{CXX} ${CMAKE_CXX_COMPILER})\n") endif() +# Workaround for bad patchelf interaction with binutils 2.43.50 +# https://github.com/LadybirdBrowser/ladybird/issues/2149 +# https://github.com/microsoft/vcpkg/issues/41576 +# https://github.com/NixOS/patchelf/issues/568 +# https://bugzilla.redhat.com/show_bug.cgi?id=2319341 +if (LINUX AND NOT LAGOM_USE_LINKER) + string(APPEND EXTRA_VCPKG_VARIABLES "set(ENV{LDFLAGS} -Wl,-z,noseparate-code)\n") +endif() + file(WRITE "${CMAKE_CURRENT_BINARY_DIR}/build-vcpkg-variables.cmake" "${EXTRA_VCPKG_VARIABLES}")