diff --git a/cmake/modules/AddSwift.cmake b/cmake/modules/AddSwift.cmake index ed28ab1891dba..289716edfd496 100644 --- a/cmake/modules/AddSwift.cmake +++ b/cmake/modules/AddSwift.cmake @@ -995,7 +995,7 @@ function(add_swift_host_tool executable) endif() # Opt-out of OpenBSD BTCFI if instructed where it is enforced by default. - if(SWIFT_HOST_VARIANT_SDK STREQUAL "OPENBSD" AND SWIFT_HOST_VARIANT_ARCH STREQUAL "aarch64" AND NOT SWIFT_OPENBSD_BTCFI) + if(SWIFT_HOST_VARIANT_SDK STREQUAL "OPENBSD" AND SWIFT_HOST_VARIANT_ARCH MATCHES "aarch64|x86_64" AND NOT SWIFT_OPENBSD_BTCFI) target_link_options(${executable} PRIVATE "LINKER:-z,nobtcfi") endif() diff --git a/lib/Basic/Platform.cpp b/lib/Basic/Platform.cpp index 8c6f1200c0a39..c7f0bfa2757aa 100644 --- a/lib/Basic/Platform.cpp +++ b/lib/Basic/Platform.cpp @@ -150,7 +150,10 @@ bool swift::tripleRequiresRPathForSwiftLibrariesInOS( } bool swift::tripleBTCFIByDefaultInOpenBSD(const llvm::Triple &triple) { - return triple.isOSOpenBSD() && triple.getArch() == llvm::Triple::aarch64; + return triple.isOSOpenBSD() && ( + triple.getArch() == llvm::Triple::aarch64 || + triple.getArch() == llvm::Triple::x86_64); + } DarwinPlatformKind swift::getDarwinPlatformKind(const llvm::Triple &triple) {