<div dir="ltr"><div class="gmail_extra"><div class="gmail_quote">On Sun, May 15, 2016 at 12:29 PM, Davide Italiano via llvm-commits <span dir="ltr"><<a href="mailto:llvm-commits@lists.llvm.org" target="_blank">llvm-commits@lists.llvm.org</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Author: davide<br>
Date: Sun May 15 14:29:38 2016<br>
New Revision: 269605<br>
<br>
URL: <a href="http://llvm.org/viewvc/llvm-project?rev=269605&view=rev" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-project?rev=269605&view=rev</a><br>
Log:<br>
[LTO] Add the ability to specify a subset of passes to run.<br>
<br>
Differential Revision: <a href="http://reviews.llvm.org/D20267" rel="noreferrer" target="_blank">http://reviews.llvm.org/D20267</a><br>
<br>
Added:<br>
lld/trunk/test/ELF/lto/ltopasses-custom.ll<br>
Modified:<br>
lld/trunk/ELF/CMakeLists.txt<br>
lld/trunk/ELF/Config.h<br>
lld/trunk/ELF/Driver.cpp<br>
lld/trunk/ELF/LTO.cpp<br>
lld/trunk/ELF/Options.td<br>
<br>
Modified: lld/trunk/ELF/CMakeLists.txt<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/lld/trunk/ELF/CMakeLists.txt?rev=269605&r1=269604&r2=269605&view=diff" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-project/lld/trunk/ELF/CMakeLists.txt?rev=269605&r1=269604&r2=269605&view=diff</a><br>
==============================================================================<br>
--- lld/trunk/ELF/CMakeLists.txt (original)<br>
+++ lld/trunk/ELF/CMakeLists.txt Sun May 15 14:29:38 2016<br>
@@ -31,6 +31,7 @@ add_lld_library(lldELF<br>
Linker<br>
Object<br>
Option<br>
+ Passes<br>
MC<br>
Support<br>
Target<br>
<br>
Modified: lld/trunk/ELF/Config.h<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/lld/trunk/ELF/Config.h?rev=269605&r1=269604&r2=269605&view=diff" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-project/lld/trunk/ELF/Config.h?rev=269605&r1=269604&r2=269605&view=diff</a><br>
==============================================================================<br>
--- lld/trunk/ELF/Config.h (original)<br>
+++ lld/trunk/ELF/Config.h Sun May 15 14:29:38 2016<br>
@@ -44,6 +44,7 @@ struct Configuration {<br>
llvm::StringRef Emulation;<br>
llvm::StringRef Fini;<br>
llvm::StringRef Init;<br>
+ llvm::StringRef LtoNewPmPasses;<br>
llvm::StringRef OutputFile;<br>
llvm::StringRef SoName;<br>
llvm::StringRef Sysroot;<br>
<br>
Modified: lld/trunk/ELF/Driver.cpp<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/lld/trunk/ELF/Driver.cpp?rev=269605&r1=269604&r2=269605&view=diff" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-project/lld/trunk/ELF/Driver.cpp?rev=269605&r1=269604&r2=269605&view=diff</a><br>
==============================================================================<br>
--- lld/trunk/ELF/Driver.cpp (original)<br>
+++ lld/trunk/ELF/Driver.cpp Sun May 15 14:29:38 2016<br>
@@ -337,6 +337,7 @@ void LinkerDriver::readConfigs(opt::Inpu<br>
Config->Entry = getString(Args, OPT_entry);<br>
Config->Fini = getString(Args, OPT_fini, "_fini");<br>
Config->Init = getString(Args, OPT_init, "_init");<br>
+ Config->LtoNewPmPasses = getString(Args, OPT_lto_newpm_passes);<br>
Config->OutputFile = getString(Args, OPT_o);<br>
Config->SoName = getString(Args, OPT_soname);<br>
Config->Sysroot = getString(Args, OPT_sysroot);<br>
@@ -495,6 +496,8 @@ template <class ELFT> void LinkerDriver:<br>
Symtab.scanVersionScript();<br>
<br>
Symtab.addCombinedLtoObject();<br>
+ if (HasError)<br>
+ return;<br>
<br>
for (auto *Arg : Args.filtered(OPT_wrap))<br>
Symtab.wrap(Arg->getValue());<br>
<br>
Modified: lld/trunk/ELF/LTO.cpp<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/lld/trunk/ELF/LTO.cpp?rev=269605&r1=269604&r2=269605&view=diff" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-project/lld/trunk/ELF/LTO.cpp?rev=269605&r1=269604&r2=269605&view=diff</a><br>
==============================================================================<br>
--- lld/trunk/ELF/LTO.cpp (original)<br>
+++ lld/trunk/ELF/LTO.cpp Sun May 15 14:29:38 2016<br>
@@ -13,6 +13,9 @@<br>
#include "Error.h"<br>
#include "InputFiles.h"<br>
#include "Symbols.h"<br>
+#include "llvm/Analysis/AliasAnalysis.h"<br>
+#include "llvm/Analysis/CGSCCPassManager.h"<br>
+#include "llvm/Analysis/LoopPassManager.h"<br>
#include "llvm/Analysis/TargetLibraryInfo.h"<br>
#include "llvm/Analysis/TargetTransformInfo.h"<br>
#include "llvm/Bitcode/ReaderWriter.h"<br>
@@ -20,13 +23,16 @@<br>
#include "llvm/CodeGen/ParallelCG.h"<br>
#include "llvm/IR/AutoUpgrade.h"<br>
#include "llvm/IR/LegacyPassManager.h"<br>
+#include "llvm/IR/PassManager.h"<br>
#include "llvm/Linker/IRMover.h"<br>
+#include "llvm/Passes/PassBuilder.h"<br>
#include "llvm/Support/StringSaver.h"<br>
#include "llvm/Support/TargetRegistry.h"<br>
#include "llvm/Target/TargetMachine.h"<br>
#include "llvm/Transforms/IPO.h"<br>
#include "llvm/Transforms/IPO/PassManagerBuilder.h"<br>
#include "llvm/Transforms/Utils/ModuleUtils.h"<br>
+#include <llvm/IR/Verifier.h><br>
<br>
using namespace llvm;<br>
using namespace llvm::object;<br>
@@ -56,10 +62,44 @@ static void saveBCFile(Module &M, String<br>
WriteBitcodeToFile(&M, OS, /* ShouldPreserveUseListOrder */ true);<br>
}<br>
<br>
-// Run LTO passes.<br>
-// Note that the gold plugin has a similar piece of code, so<br>
-// it is probably better to move this code to a common place.<br>
-static void runLTOPasses(Module &M, TargetMachine &TM) {<br>
+static void runNewCustomLtoPasses(Module &M, TargetMachine &TM) {<br>
+ PassBuilder PB(&TM);<br>
+<br>
+ AAManager AA;<br>
+ LoopAnalysisManager LAM;<br>
+ FunctionAnalysisManager FAM;<br>
+ CGSCCAnalysisManager CGAM;<br>
+ ModuleAnalysisManager MAM;<br>
+<br>
+ // Register the AA manager first so that our version is the one used.<br>
+ FAM.registerPass([&] { return std::move(AA); });<br>
+<br>
+ // Register all the basic analyses with the managers.<br>
+ PB.registerModuleAnalyses(MAM);<br>
+ PB.registerCGSCCAnalyses(CGAM);<br>
+ PB.registerFunctionAnalyses(FAM);<br>
+ PB.registerLoopAnalyses(LAM);<br>
+ PB.crossRegisterProxies(LAM, FAM, CGAM, MAM);<br>
+<br>
+ ModulePassManager MPM;<br>
+ if (!Config->DisableVerify)<br>
+ MPM.addPass(VerifierPass());<br>
+<br>
+ // Now, add all the passes we've been requested to.<br>
+ if (!PB.parsePassPipeline(MPM, Config->LtoNewPmPasses)) {<br></blockquote><div><br></div><div>Is there any way to validate a string earlier than this? It would not only make error handling simpler but also make it more user friendly as user will get an error message immediately rather than after all symbols are resolved.</div><div><br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
+ error("unable to parse pass pipeline description: " +<br>
+ Config->LtoNewPmPasses);<br>
+ return;<br>
+ }<br>
+<br>
+ if (!Config->DisableVerify)<br>
+ MPM.addPass(VerifierPass());<br>
+ MPM.run(M, MAM);<br>
+}<br>
+<br>
+static void runOldLtoPasses(Module &M, TargetMachine &TM) {<br>
+ // Note that the gold plugin has a similar piece of code, so<br>
+ // it is probably better to move this code to a common place.<br>
legacy::PassManager LtoPasses;<br>
LtoPasses.add(createTargetTransformInfoWrapperPass(TM.getTargetIRAnalysis()));<br>
PassManagerBuilder PMB;<br>
@@ -71,6 +111,21 @@ static void runLTOPasses(Module &M, Targ<br>
PMB.OptLevel = Config->LtoO;<br>
PMB.populateLTOPassManager(LtoPasses);<br>
LtoPasses.run(M);<br>
+}<br>
+<br>
+static void runLTOPasses(Module &M, TargetMachine &TM) {<br>
+ if (!Config->LtoNewPmPasses.empty()) {<br>
+ // The user explicitly asked for a set of passes to be run.<br>
+ // This needs the new PM to work as there's no clean way to<br>
+ // pass a set of passes to run in the legacy PM.<br>
+ runNewCustomLtoPasses(M, TM);<br>
+ if (HasError)<br>
+ return;<br>
+ } else {<br>
+ // Run the 'default' set of LTO passes. This code still uses<br>
+ // the legacy PM as the new one is not the default.<br>
+ runOldLtoPasses(M, TM);<br>
+ }<br>
<br>
if (Config->SaveTemps)<br>
saveBCFile(M, ".lto.opt.bc");<br>
@@ -226,6 +281,8 @@ std::vector<std::unique_ptr<InputFile>><br>
<br>
std::unique_ptr<TargetMachine> TM = CreateTargetMachine();<br>
runLTOPasses(*Combined, *TM);<br>
+ if (HasError)<br>
+ return {};<br>
<br>
return runSplitCodegen(CreateTargetMachine);<br>
}<br>
<br>
Modified: lld/trunk/ELF/Options.td<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/lld/trunk/ELF/Options.td?rev=269605&r1=269604&r2=269605&view=diff" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-project/lld/trunk/ELF/Options.td?rev=269605&r1=269604&r2=269605&view=diff</a><br>
==============================================================================<br>
--- lld/trunk/ELF/Options.td (original)<br>
+++ lld/trunk/ELF/Options.td Sun May 15 14:29:38 2016<br>
@@ -255,6 +255,8 @@ def alias_version_script_version_script<br>
// LTO-related options.<br>
def lto_jobs : Joined<["--"], "lto-jobs=">,<br>
HelpText<"Number of threads to run codegen">;<br>
+def lto_newpm_passes : Joined<["--"], "lto-newpm-passes=">,<br>
+ HelpText<"Passes to run during LTO">;<br>
def disable_verify : Flag<["-"], "disable-verify">;<br>
def mllvm : Separate<["-"], "mllvm">;<br>
def save_temps : Flag<["-"], "save-temps">;<br>
<br>
Added: lld/trunk/test/ELF/lto/ltopasses-custom.ll<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/lld/trunk/test/ELF/lto/ltopasses-custom.ll?rev=269605&view=auto" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-project/lld/trunk/test/ELF/lto/ltopasses-custom.ll?rev=269605&view=auto</a><br>
==============================================================================<br>
--- lld/trunk/test/ELF/lto/ltopasses-custom.ll (added)<br>
+++ lld/trunk/test/ELF/lto/ltopasses-custom.ll Sun May 15 14:29:38 2016<br>
@@ -0,0 +1,29 @@<br>
+; REQUIRES: x86<br>
+; RUN: llvm-as %s -o %t.o<br>
+; RUN: ld.lld -m elf_x86_64 %t.o -o %t.so -save-temps --lto-newpm-passes=ipsccp -shared<br>
+; RUN: ld.lld -m elf_x86_64 %t.o -o %t2.so -save-temps --lto-newpm-passes=loweratomic -shared<br>
+; RUN: llvm-dis %t.so.lto.opt.bc -o - | FileCheck %s<br>
+; RUN: llvm-dis %t2.so.lto.opt.bc -o - | FileCheck %s --check-prefix=ATOMIC<br>
+<br>
+target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"<br>
+target triple = "x86_64-unknown-linux-gnu"<br>
+<br>
+define void @barrier() {<br>
+ fence seq_cst<br>
+ ret void<br>
+}<br>
+<br>
+; IPSCCP won't remove the fence.<br>
+; CHECK: define void @barrier() {<br>
+; CHECK-NEXT: fence seq_cst<br>
+; CHECK-NEXT: ret void<br>
+<br>
+; LowerAtomic will remove the fence.<br>
+; ATOMIC: define void @barrier() {<br>
+; ATOMIC-NEXT: ret void<br>
+<br>
+; Check that invalid passes are rejected gracefully.<br>
+; RUN: not ld.lld -m elf_x86_64 %t.o -o %t2.so \<br>
+; RUN: --lto-newpm-passes=iamnotapass -shared 2>&1 | \<br>
+; RUN: FileCheck %s --check-prefix=INVALID<br>
+; INVALID: unable to parse pass pipeline description: iamnotapass<br>
<br>
<br>
_______________________________________________<br>
llvm-commits mailing list<br>
<a href="mailto:llvm-commits@lists.llvm.org">llvm-commits@lists.llvm.org</a><br>
<a href="http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-commits" rel="noreferrer" target="_blank">http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-commits</a><br>
</blockquote></div><br></div></div>