diff options
author | Fangrui Song <maskray@google.com> | 2018-12-20 22:46:01 +0000 |
---|---|---|
committer | Fangrui Song <maskray@google.com> | 2018-12-20 22:46:01 +0000 |
commit | 51fe635f81aea34901cc329e1a375703c980d7ef (patch) | |
tree | b3842e3a4653792e4ab411bd45c1ac5173ae5f7a /lldb/packages/Python/lldbsuite/test/python_api/class_members | |
parent | 232d22f380eb1e9a9a1e71500b90d6f269a071b3 (diff) | |
download | bcm5719-llvm-51fe635f81aea34901cc329e1a375703c980d7ef.tar.gz bcm5719-llvm-51fe635f81aea34901cc329e1a375703c980d7ef.zip |
[ELF] Move IsNeeded logic from SymbolTable::addShared to MarkLive, and check IsUsedInRegularObj
Summary:
In glibc, libc.so is a linker script with an as-needed dependency on ld-linux-x86-64.so.2
GROUP ( /lib/x86_64-linux-gnu/libc.so.6 /usr/lib/x86_64-linux-gnu/libc_nonshared.a AS_NEEDED ( /lib/x86_64-linux-gnu/ld-linux-x86-64.so.2 ) )
ld-linux-x86-64.so.2 (as-needed) defines some symbols which resolve undefined references in libc.so.6, it will therefore be added as a DT_NEEDED entry, which isn't necessary.
The test case as-needed-not-in-regular.s emulates the libc.so scenario, where ld.bfd and gold don't add DT_NEEDED for a.so
The relevant code in gold/resolve.cc:
// If we have a non-WEAK reference from a regular object to a
// dynamic object, mark the dynamic object as needed.
if (to->is_from_dynobj() && to->in_reg() && !to->is_undef_binding_weak())
to->object()->set_is_needed();
in_reg() appears to do something similar to IsUsedInRegularObj.
This patch makes lld do the similar thing, but moves the check from
addShared to a later stage MarkLive where all symbols are scanned.
Reviewers: ruiu, pcc, espindola
Reviewed By: ruiu
Subscribers: emaste, arichardson, llvm-commits
Differential Revision: https://reviews.llvm.org/D55902
llvm-svn: 349849
Diffstat (limited to 'lldb/packages/Python/lldbsuite/test/python_api/class_members')
0 files changed, 0 insertions, 0 deletions