[PATCH] D129540: [lld-macho] Enable EH frame relocation / pruning
Jez Ng via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Wed Jul 13 18:14:24 PDT 2022
This revision was automatically updated to reflect the committed changes.
Closed by commit rG403d61aeddec: [lld-macho] Enable EH frame relocation / pruning (authored by int3).
Repository:
rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D129540/new/
https://reviews.llvm.org/D129540
Files:
lld/MachO/Config.h
lld/MachO/Driver.cpp
lld/MachO/InputFiles.cpp
lld/docs/ReleaseNotes.rst
Index: lld/docs/ReleaseNotes.rst
===================================================================
--- lld/docs/ReleaseNotes.rst
+++ lld/docs/ReleaseNotes.rst
@@ -65,7 +65,11 @@
MachO Improvements
------------------
-* Item 1.
+* We now support proper relocation and pruning of EH frames. **Note:** this
+ comes at some performance overhead on x86_64 builds, and we recommend adding
+ the ``-femit-compact-unwind=no-compact-unwind`` compile flag to avoid it.
+ (`D129540 <https://reviews.llvm.org/D129540>`_,
+ `D122258 <https://reviews.llvm.org/D122258>`_)
WebAssembly Improvements
------------------------
Index: lld/MachO/InputFiles.cpp
===================================================================
--- lld/MachO/InputFiles.cpp
+++ lld/MachO/InputFiles.cpp
@@ -347,7 +347,7 @@
section.subsections.push_back({0, isec});
} else if (auto recordSize = getRecordSize(segname, name)) {
splitRecords(*recordSize);
- } else if (config->parseEhFrames && name == section_names::ehFrame &&
+ } else if (name == section_names::ehFrame &&
segname == segment_names::text) {
splitEhFrames(data, *sections.back());
} else if (segname == segment_names::llvm) {
@@ -1117,7 +1117,7 @@
}
if (compactUnwindSection)
registerCompactUnwind(*compactUnwindSection);
- if (config->parseEhFrames && ehFrameSection)
+ if (ehFrameSection)
registerEhFrames(*ehFrameSection);
}
Index: lld/MachO/Driver.cpp
===================================================================
--- lld/MachO/Driver.cpp
+++ lld/MachO/Driver.cpp
@@ -1305,7 +1305,6 @@
config->callGraphProfileSort = args.hasFlag(
OPT_call_graph_profile_sort, OPT_no_call_graph_profile_sort, true);
config->printSymbolOrder = args.getLastArgValue(OPT_print_symbol_order);
- config->parseEhFrames = static_cast<bool>(getenv("LLD_IN_TEST"));
// FIXME: Add a commandline flag for this too.
config->zeroModTime = getenv("ZERO_AR_DATE");
Index: lld/MachO/Config.h
===================================================================
--- lld/MachO/Config.h
+++ lld/MachO/Config.h
@@ -131,9 +131,6 @@
bool omitDebugInfo = false;
bool warnDylibInstallName = false;
bool ignoreOptimizationHints = false;
- // Temporary config flag that will be removed once we have fully implemented
- // support for __eh_frame.
- bool parseEhFrames = false;
uint32_t headerPad;
uint32_t dylibCompatibilityVersion = 0;
uint32_t dylibCurrentVersion = 0;
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D129540.444482.patch
Type: text/x-patch
Size: 2494 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20220714/a0788952/attachment.bin>
More information about the llvm-commits
mailing list