diff options
author | Teresa Johnson <tejohnson@google.com> | 2016-08-11 14:58:12 +0000 |
---|---|---|
committer | Teresa Johnson <tejohnson@google.com> | 2016-08-11 14:58:12 +0000 |
commit | 9ba95f99f3703fd06ce5912343526c2cc6ba353e (patch) | |
tree | bf52a79d2f8cf0359e7a9e7a932e37772b8d6fe8 /llvm/lib/Object/IRObjectFile.cpp | |
parent | 3818f1b38ae7b29dfeed0f11cff1a6b30fcc4f0e (diff) | |
download | bcm5719-llvm-9ba95f99f3703fd06ce5912343526c2cc6ba353e.tar.gz bcm5719-llvm-9ba95f99f3703fd06ce5912343526c2cc6ba353e.zip |
Restore "Resolution-based LTO API."
This restores commit r278330, with fixes for a few bot failures:
- Fix a late change I had made to the save temps output file that I
missed due to existing files sitting on my disk
- Fix a bunch of Windows bot failures with "ambiguous call to overloaded
function" due to confusion between llvm::make_unique vs
std::make_unique (preface the new make_unique calls with "llvm::")
- Attempt to fix a modules bot failure by adding a missing include
to LTO/Config.h.
Original change:
Resolution-based LTO API.
Summary:
This introduces a resolution-based LTO API. The main advantage of this API over
existing APIs is that it allows the linker to supply a resolution for each
symbol in each object, rather than the combined object as a whole. This will
become increasingly important for use cases such as ThinLTO which require us
to process symbol resolutions in a more complicated way than just adjusting
linkage.
Patch by Peter Collingbourne.
Reviewers: rafael, tejohnson, mehdi_amini
Subscribers: lhames, tejohnson, mehdi_amini, llvm-commits
Differential Revision: https://reviews.llvm.org/D20268
llvm-svn: 278338
Diffstat (limited to 'llvm/lib/Object/IRObjectFile.cpp')
-rw-r--r-- | llvm/lib/Object/IRObjectFile.cpp | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/llvm/lib/Object/IRObjectFile.cpp b/llvm/lib/Object/IRObjectFile.cpp index 42c8ecd62da..f86576f3d69 100644 --- a/llvm/lib/Object/IRObjectFile.cpp +++ b/llvm/lib/Object/IRObjectFile.cpp @@ -324,5 +324,5 @@ llvm::object::IRObjectFile::create(MemoryBufferRef Object, return EC; std::unique_ptr<Module> &M = MOrErr.get(); - return llvm::make_unique<IRObjectFile>(Object, std::move(M)); + return llvm::make_unique<IRObjectFile>(BCOrErr.get(), std::move(M)); } |