[PATCH] D111863: [libunwind] Add an interface for dynamic .eh_frame registration
Peter S. Housel via Phabricator via cfe-commits
cfe-commits at lists.llvm.org
Thu Oct 14 22:15:45 PDT 2021
housel added a comment.
In D111863#3065992 <https://reviews.llvm.org/D111863#3065992>, @MaskRay wrote:
> I looked at the libgcc mechanism at one time. I remember that in most cases it just uses `PT_GNU_EH_FRAME` and these eh_frame boundary registry functions are not needed.
> Can ORC just use `PT_GNU_EH_FRAME`?
ORC doesn't go through the system dynamic loader, so there's no program header (JITLink doesn't generate one). None of the dynamic loaders I've looked at have any way to dynamically register program headers so that they'll be returned by `dl_iterate_phdr`. With ORC, code and data segments, including `.eh_frame` segments, get allocated in the target execution space and initialized by the JITLink memory manager, and the ORC runtime calling these registration functions is the only way libunwind will know about these tables.
Repository:
rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D111863/new/
https://reviews.llvm.org/D111863
More information about the cfe-commits
mailing list