summaryrefslogtreecommitdiffstats
path: root/contrib/llvm/patches/patch-04-add-llvm-gvn-option.diff
diff options
context:
space:
mode:
Diffstat (limited to 'contrib/llvm/patches/patch-04-add-llvm-gvn-option.diff')
-rw-r--r--contrib/llvm/patches/patch-04-add-llvm-gvn-option.diff31
1 files changed, 31 insertions, 0 deletions
diff --git a/contrib/llvm/patches/patch-04-add-llvm-gvn-option.diff b/contrib/llvm/patches/patch-04-add-llvm-gvn-option.diff
new file mode 100644
index 0000000..5f31623
--- /dev/null
+++ b/contrib/llvm/patches/patch-04-add-llvm-gvn-option.diff
@@ -0,0 +1,31 @@
+Add an llvm option to enable/disable running the global value numbering
+optimization pass. Disabling this pass helps to minimize the size of
+boot2.
+
+Introduced here: http://svnweb.freebsd.org/changeset/base/274968
+
+Index: lib/Transforms/IPO/PassManagerBuilder.cpp
+===================================================================
+--- lib/Transforms/IPO/PassManagerBuilder.cpp
++++ lib/Transforms/IPO/PassManagerBuilder.cpp
+@@ -78,6 +78,10 @@ static cl::opt<bool>
+ EnableMLSM("mlsm", cl::init(true), cl::Hidden,
+ cl::desc("Enable motion of merged load and store"));
+
++static cl::opt<bool> EnableGVN("enable-gvn",
++ cl::init(true), cl::Hidden,
++ cl::desc("Run the global value numbering pass"));
++
+ PassManagerBuilder::PassManagerBuilder() {
+ OptLevel = 2;
+ SizeLevel = 0;
+@@ -244,7 +248,8 @@ void PassManagerBuilder::populateModulePassManager
+ if (OptLevel > 1) {
+ if (EnableMLSM)
+ MPM.add(createMergedLoadStoreMotionPass()); // Merge ld/st in diamonds
+- MPM.add(createGVNPass(DisableGVNLoadPRE)); // Remove redundancies
++ if (EnableGVN)
++ MPM.add(createGVNPass(DisableGVNLoadPRE)); // Remove redundancies
+ }
+ MPM.add(createMemCpyOptPass()); // Remove memcpy / form memset
+ MPM.add(createSCCPPass()); // Constant prop with SCCP
OpenPOWER on IntegriCloud