llvm-project/lld/lib
Nick Kledzik 8fc67fba01 [mach-o] Support re-exported dylibs
In general two-level namespace means each program records exactly which dylib
each undefined (imported) symbol comes from.  But, sometimes the implementor
wants to hide the implementation dylib.  For instance libSytem.dylib is the base
dylib all Darwin programs must link with.  A few years ago it was split up
into two dozen dylibs by all are hidden behind libSystem.dylib which re-exports
each sub-dylib.  All clients still think libSystem.dylib is the implementor.

To support this, the linker must load "indirect" dylibs and not just the
"direct" dylibs specified on the command line.  This is done in the
createImplicitFiles() method after all command line specified files are
loaded.  Since an indirect dylib may have already been loaded as a direct dylib
(or indirectly via a previous direct dylib), the MachOLinkingContext keeps
a list of all loaded dylibs.

With this change hello world can now be linked against the real OS or SDK.

llvm-svn: 215605
2014-08-13 23:55:41 +00:00
..
Core Change the signature of insertElementAt and rename addInputElementFront 2014-07-24 00:08:22 +00:00
Driver [mach-o] Support re-exported dylibs 2014-08-13 23:55:41 +00:00
Passes Fix unsafe memory access 2014-07-25 19:46:31 +00:00
ReaderWriter [mach-o] Support re-exported dylibs 2014-08-13 23:55:41 +00:00
CMakeLists.txt Add the core architecture for the lld driver. 2012-12-08 00:47:36 +00:00
Makefile Initial set of Makefiles 2014-06-04 09:54:07 +00:00