diff options
Diffstat (limited to 'llvm/lib')
-rw-r--r-- | llvm/lib/LTO/LTO.cpp | 40 | ||||
-rw-r--r-- | llvm/lib/LTO/LTOBackend.cpp | 10 |
2 files changed, 29 insertions, 21 deletions
diff --git a/llvm/lib/LTO/LTO.cpp b/llvm/lib/LTO/LTO.cpp index bd11085ed1c..8ceb5a2c1c8 100644 --- a/llvm/lib/LTO/LTO.cpp +++ b/llvm/lib/LTO/LTO.cpp @@ -365,27 +365,29 @@ Error LTO::runRegularLTO(AddOutputFn AddOutput) { !Conf.PreOptModuleHook(0, *RegularLTO.CombinedModule)) return Error(); - for (const auto &R : GlobalResolutions) { - if (R.second.IRName.empty()) - continue; - if (R.second.Partition != 0 && - R.second.Partition != GlobalResolution::External) - continue; + if (!Conf.CodeGenOnly) { + for (const auto &R : GlobalResolutions) { + if (R.second.IRName.empty()) + continue; + if (R.second.Partition != 0 && + R.second.Partition != GlobalResolution::External) + continue; + + GlobalValue *GV = + RegularLTO.CombinedModule->getNamedValue(R.second.IRName); + // Ignore symbols defined in other partitions. + if (!GV || GV->hasLocalLinkage()) + continue; + GV->setUnnamedAddr(R.second.UnnamedAddr ? GlobalValue::UnnamedAddr::Global + : GlobalValue::UnnamedAddr::None); + if (R.second.Partition == 0) + GV->setLinkage(GlobalValue::InternalLinkage); + } - GlobalValue *GV = RegularLTO.CombinedModule->getNamedValue(R.second.IRName); - // Ignore symbols defined in other partitions. - if (!GV || GV->hasLocalLinkage()) - continue; - GV->setUnnamedAddr(R.second.UnnamedAddr ? GlobalValue::UnnamedAddr::Global - : GlobalValue::UnnamedAddr::None); - if (R.second.Partition == 0) - GV->setLinkage(GlobalValue::InternalLinkage); + if (Conf.PostInternalizeModuleHook && + !Conf.PostInternalizeModuleHook(0, *RegularLTO.CombinedModule)) + return Error(); } - - if (Conf.PostInternalizeModuleHook && - !Conf.PostInternalizeModuleHook(0, *RegularLTO.CombinedModule)) - return Error(); - return backend(Conf, AddOutput, RegularLTO.ParallelCodeGenParallelismLevel, std::move(RegularLTO.CombinedModule)); } diff --git a/llvm/lib/LTO/LTOBackend.cpp b/llvm/lib/LTO/LTOBackend.cpp index 935152b970d..a89364e46a0 100644 --- a/llvm/lib/LTO/LTOBackend.cpp +++ b/llvm/lib/LTO/LTOBackend.cpp @@ -224,8 +224,9 @@ Error lto::backend(Config &C, AddOutputFn AddOutput, std::unique_ptr<TargetMachine> TM = createTargetMachine(C, M->getTargetTriple(), *TOrErr); - if (!opt(C, TM.get(), 0, *M, /*IsThinLto=*/false)) - return Error(); + if (!C.CodeGenOnly) + if (!opt(C, TM.get(), 0, *M, /*IsThinLto=*/false)) + return Error(); if (ParallelCodeGenParallelismLevel == 1) codegen(C, TM.get(), AddOutput, 0, *M); @@ -247,6 +248,11 @@ Error lto::thinBackend(Config &Conf, unsigned Task, AddOutputFn AddOutput, std::unique_ptr<TargetMachine> TM = createTargetMachine(Conf, Mod.getTargetTriple(), *TOrErr); + if (Conf.CodeGenOnly) { + codegen(Conf, TM.get(), AddOutput, Task, Mod); + return Error(); + } + if (Conf.PreOptModuleHook && !Conf.PreOptModuleHook(Task, Mod)) return Error(); |