diff options
author | Nadav Rotem <nrotem@apple.com> | 2012-10-29 16:36:25 +0000 |
---|---|---|
committer | Nadav Rotem <nrotem@apple.com> | 2012-10-29 16:36:25 +0000 |
commit | c59ae207ef7b79a2bbfe2f36ac7512426ef3c64e (patch) | |
tree | 849cfc8663fed2aebd007b114df54d8b36aa368c | |
parent | aad8ad1c36074dc2027d716a6d7bebe6d41cbed3 (diff) | |
download | bcm5719-llvm-c59ae207ef7b79a2bbfe2f36ac7512426ef3c64e.tar.gz bcm5719-llvm-c59ae207ef7b79a2bbfe2f36ac7512426ef3c64e.zip |
Change the PassManagerBuilder (used by -O3) loop vectorizer flag from -vectorize to -vectorize-loops because we dont want to share the same flag as the bb-vectorizer.
llvm-svn: 166937
-rw-r--r-- | llvm/docs/ReleaseNotes.html | 3 | ||||
-rw-r--r-- | llvm/include/llvm/Transforms/IPO/PassManagerBuilder.h | 3 | ||||
-rw-r--r-- | llvm/lib/Transforms/IPO/PassManagerBuilder.cpp | 12 |
3 files changed, 12 insertions, 6 deletions
diff --git a/llvm/docs/ReleaseNotes.html b/llvm/docs/ReleaseNotes.html index eb12b339a47..fa986a85510 100644 --- a/llvm/docs/ReleaseNotes.html +++ b/llvm/docs/ReleaseNotes.html @@ -468,9 +468,10 @@ Release Notes</a>.</h1> <p> Loop Vectorizer - We've added a loop vectorizer and we are now able to vectorize small loops. The loop vectorizer is disabled by default and - can be enabled using the <b>-mllvm -vectorize</b> flag. + can be enabled using the <b>-mllvm -vectorize-loops</b> flag. The SIMD vector width can be specified using the flag <b>-mllvm -force-vector-width=4</b>. + The defaule value is <b>0</b> which means auto-select. <br/> We can now vectorize this code: diff --git a/llvm/include/llvm/Transforms/IPO/PassManagerBuilder.h b/llvm/include/llvm/Transforms/IPO/PassManagerBuilder.h index 47ce90265bd..68557bd5f67 100644 --- a/llvm/include/llvm/Transforms/IPO/PassManagerBuilder.h +++ b/llvm/include/llvm/Transforms/IPO/PassManagerBuilder.h @@ -103,7 +103,8 @@ public: bool DisableSimplifyLibCalls; bool DisableUnitAtATime; bool DisableUnrollLoops; - bool Vectorize; + bool BBVectorize; + bool LoopVectorize; private: /// ExtensionList - This is list of all of the extensions that are registered. diff --git a/llvm/lib/Transforms/IPO/PassManagerBuilder.cpp b/llvm/lib/Transforms/IPO/PassManagerBuilder.cpp index e3bc94e7e67..2b16e20e563 100644 --- a/llvm/lib/Transforms/IPO/PassManagerBuilder.cpp +++ b/llvm/lib/Transforms/IPO/PassManagerBuilder.cpp @@ -33,7 +33,10 @@ using namespace llvm; static cl::opt<bool> -RunVectorization("vectorize", cl::desc("Run vectorization passes")); +RunLoopVectorization("vectorize-loops", cl::desc("Run the Loop vectorization passes")); + +static cl::opt<bool> +RunBBVectorization("vectorize", cl::desc("Run the BB vectorization passes")); static cl::opt<bool> UseGVNAfterVectorization("use-gvn-after-vectorization", @@ -52,7 +55,8 @@ PassManagerBuilder::PassManagerBuilder() { DisableSimplifyLibCalls = false; DisableUnitAtATime = false; DisableUnrollLoops = false; - Vectorize = RunVectorization; + BBVectorize = RunBBVectorization; + LoopVectorize = RunLoopVectorization; } PassManagerBuilder::~PassManagerBuilder() { @@ -185,7 +189,7 @@ void PassManagerBuilder::populateModulePassManager(PassManagerBase &MPM) { MPM.add(createLoopIdiomPass()); // Recognize idioms like memset. MPM.add(createLoopDeletionPass()); // Delete dead loops - if (Vectorize) { + if (LoopVectorize) { MPM.add(createLoopVectorizePass()); MPM.add(createLICMPass()); } @@ -208,7 +212,7 @@ void PassManagerBuilder::populateModulePassManager(PassManagerBase &MPM) { addExtensionsToPM(EP_ScalarOptimizerLate, MPM); - if (Vectorize) { + if (BBVectorize) { MPM.add(createBBVectorizePass()); MPM.add(createInstructionCombiningPass()); if (OptLevel > 1 && UseGVNAfterVectorization) |