summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Transforms
diff options
context:
space:
mode:
authorMatt Arsenault <Matthew.Arsenault@amd.com>2013-10-01 18:05:30 +0000
committerMatt Arsenault <Matthew.Arsenault@amd.com>2013-10-01 18:05:30 +0000
commit517d84e268fb90ca98cd765fc1699cd81f7d5f28 (patch)
treee66b0c812d8d9e0c11ff1b5a61d9457ecfcb082d /llvm/lib/Transforms
parent8cc523f5f7a5c89f036d14d37c8048f95d20a6d6 (diff)
downloadbcm5719-llvm-517d84e268fb90ca98cd765fc1699cd81f7d5f28.tar.gz
bcm5719-llvm-517d84e268fb90ca98cd765fc1699cd81f7d5f28.zip
Don't merge tiny functions.
It's silly to merge functions like these: define void @foo(i32 %x) { ret void } define void @bar(i32 %x) { ret void } to get define void @bar(i32) { tail call void @foo(i32 %0) ret void } llvm-svn: 191786
Diffstat (limited to 'llvm/lib/Transforms')
-rw-r--r--llvm/lib/Transforms/IPO/MergeFunctions.cpp12
1 files changed, 12 insertions, 0 deletions
diff --git a/llvm/lib/Transforms/IPO/MergeFunctions.cpp b/llvm/lib/Transforms/IPO/MergeFunctions.cpp
index 0f09b9026eb..7e4c1668455 100644
--- a/llvm/lib/Transforms/IPO/MergeFunctions.cpp
+++ b/llvm/lib/Transforms/IPO/MergeFunctions.cpp
@@ -836,6 +836,18 @@ bool MergeFunctions::insert(ComparableFunction &NewF) {
const ComparableFunction &OldF = *Result.first;
+ // Don't merge tiny functions, since it can just end up making the function
+ // larger.
+ // FIXME: Should still merge them if they are unnamed_addr and produce an
+ // alias.
+ if (NewF.getFunc()->size() == 1) {
+ if (NewF.getFunc()->front().size() <= 2) {
+ DEBUG(dbgs() << NewF.getFunc()->getName()
+ << " is to small to bother merging\n");
+ return false;
+ }
+ }
+
// Never thunk a strong function to a weak function.
assert(!OldF.getFunc()->mayBeOverridden() ||
NewF.getFunc()->mayBeOverridden());
OpenPOWER on IntegriCloud