summaryrefslogtreecommitdiffstats
path: root/llvm/lib
diff options
context:
space:
mode:
authorMehdi Amini <mehdi.amini@apple.com>2016-04-27 04:24:10 +0000
committerMehdi Amini <mehdi.amini@apple.com>2016-04-27 04:24:10 +0000
commit360ed847bc348423d2fce9c3ed82596a972fc9bb (patch)
tree610d1baa2acf05fabd202eaa3f23cddcaa908182 /llvm/lib
parenta1b8b6cd56895236802f359926d85978f6c71a33 (diff)
downloadbcm5719-llvm-360ed847bc348423d2fce9c3ed82596a972fc9bb.tar.gz
bcm5719-llvm-360ed847bc348423d2fce9c3ed82596a972fc9bb.zip
Support "preserving" the summary information when using setModule() API in LTOCodeGenerator
Another attempt at r267655... From: Mehdi Amini <mehdi.amini@apple.com> llvm-svn: 267665
Diffstat (limited to 'llvm/lib')
-rw-r--r--llvm/lib/LTO/LTOCodeGenerator.cpp9
1 files changed, 8 insertions, 1 deletions
diff --git a/llvm/lib/LTO/LTOCodeGenerator.cpp b/llvm/lib/LTO/LTOCodeGenerator.cpp
index 01304641598..8497114f64f 100644
--- a/llvm/lib/LTO/LTOCodeGenerator.cpp
+++ b/llvm/lib/LTO/LTOCodeGenerator.cpp
@@ -18,6 +18,7 @@
#include "llvm/ADT/Statistic.h"
#include "llvm/ADT/StringExtras.h"
#include "llvm/Analysis/Passes.h"
+#include "llvm/Analysis/ModuleSummaryAnalysis.h"
#include "llvm/Analysis/TargetLibraryInfo.h"
#include "llvm/Analysis/TargetTransformInfo.h"
#include "llvm/Bitcode/ReaderWriter.h"
@@ -145,6 +146,7 @@ void LTOCodeGenerator::setModule(std::unique_ptr<LTOModule> Mod) {
MergedModule = Mod->takeModule();
TheLinker = make_unique<Linker>(*MergedModule);
+ MainModuleHasSummary = Mod->isThinLTO();
const std::vector<const char*> &Undefs = Mod->getAsmUndefinedRefs();
for (int I = 0, E = Undefs.size(); I != E; ++I)
@@ -209,8 +211,13 @@ bool LTOCodeGenerator::writeMergedModules(const char *Path) {
return false;
}
+ std::unique_ptr<ModuleSummaryIndex> Index;
+ if (MainModuleHasSummary)
+ Index = ModuleSummaryIndexBuilder(MergedModule.get()).takeIndex();
+
// write bitcode to it
- WriteBitcodeToFile(MergedModule.get(), Out.os(), ShouldEmbedUselists);
+ WriteBitcodeToFile(MergedModule.get(), Out.os(), ShouldEmbedUselists,
+ Index.get());
Out.os().close();
if (Out.os().has_error()) {
OpenPOWER on IntegriCloud