[flang-commits] [flang] [flang] [runtime] Explicitly disable EH & RTTI (PR #126920)
via flang-commits
flang-commits at lists.llvm.org
Wed Feb 12 06:50:38 PST 2025
llvmbot wrote:
<!--LLVM PR SUMMARY COMMENT-->
@llvm/pr-subscribers-flang-runtime
Author: Michał Górny (mgorny)
<details>
<summary>Changes</summary>
Explicitly disable EH & RTTI when building Flang runtime library. This fixes the runtime built when Flang is built standalone against system LLVM that was compiled with EH & RTTI enabled.
I think this change may be sufficient to lift the top-level `LLVM_ENABLE_EH` restriction from Flang. However, I'd prefer if somebody more knowledgeable decided on that.
---
Full diff: https://github.com/llvm/llvm-project/pull/126920.diff
1 Files Affected:
- (modified) flang/runtime/CMakeLists.txt (+10)
``````````diff
diff --git a/flang/runtime/CMakeLists.txt b/flang/runtime/CMakeLists.txt
index f651ea83664eb..1f4ee69598918 100644
--- a/flang/runtime/CMakeLists.txt
+++ b/flang/runtime/CMakeLists.txt
@@ -99,6 +99,15 @@ else()
set(NO_LTO_FLAGS "")
endif()
+# based on AddLLVM.cmake
+if (LLVM_COMPILER_IS_GCC_COMPATIBLE)
+ set(NO_RTTI_FLAGS "-fno-exceptions -fno-rtti")
+elseif (MSVC)
+ set(NO_RTTI_FLAGS "/EHs-c- /GR-")
+elseif (CMAKE_CXX_COMPILER_ID MATCHES "XL")
+ set(NO_RTTI_FLAGS "-qnoeh -qnortti")
+endif ()
+
configure_file(config.h.cmake config.h)
# include_directories is used here instead of target_include_directories
# because add_flang_library creates multiple objects (STATIC/SHARED, OBJECT)
@@ -107,6 +116,7 @@ include_directories(AFTER ${CMAKE_CURRENT_BINARY_DIR})
append(${NO_LTO_FLAGS} CMAKE_C_FLAGS)
append(${NO_LTO_FLAGS} CMAKE_CXX_FLAGS)
+append(${NO_RTTI_FLAGS} CMAKE_CXX_FLAGS)
# Disable libstdc++/libc++ assertions, even in an LLVM_ENABLE_ASSERTIONS build,
# to avoid an unwanted dependency on libstdc++/libc++.so.
``````````
</details>
https://github.com/llvm/llvm-project/pull/126920
More information about the flang-commits
mailing list