summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSanjoy Das <sanjoy@playingwithpointers.com>2015-12-14 19:11:40 +0000
committerSanjoy Das <sanjoy@playingwithpointers.com>2015-12-14 19:11:40 +0000
commit2a74eb0000818e4d8b9ffd12165e6d7103b83a28 (patch)
treecbb6269cf6531adc4df4e3cbf53b281b6cc92682
parent2de4d0aa18ef099d41ff07878dcad2d796b1e31e (diff)
downloadbcm5719-llvm-2a74eb0000818e4d8b9ffd12165e6d7103b83a28.tar.gz
bcm5719-llvm-2a74eb0000818e4d8b9ffd12165e6d7103b83a28.zip
Teach MergeFunctions about operand bundles
llvm-svn: 255528
-rw-r--r--llvm/lib/Transforms/IPO/MergeFunctions.cpp31
-rw-r--r--llvm/test/Feature/OperandBundles/merge-func.ll34
2 files changed, 65 insertions, 0 deletions
diff --git a/llvm/lib/Transforms/IPO/MergeFunctions.cpp b/llvm/lib/Transforms/IPO/MergeFunctions.cpp
index fb37bcd42ed..132b5872fbe 100644
--- a/llvm/lib/Transforms/IPO/MergeFunctions.cpp
+++ b/llvm/lib/Transforms/IPO/MergeFunctions.cpp
@@ -407,6 +407,7 @@ private:
int cmpMem(StringRef L, StringRef R) const;
int cmpAttrs(const AttributeSet L, const AttributeSet R) const;
int cmpRangeMetadata(const MDNode* L, const MDNode* R) const;
+ int cmpOperandBundlesSchema(const Instruction *L, const Instruction *R) const;
// The two functions undergoing comparison.
const Function *FnL, *FnR;
@@ -564,6 +565,32 @@ int FunctionComparator::cmpRangeMetadata(const MDNode* L,
return 0;
}
+int FunctionComparator::cmpOperandBundlesSchema(const Instruction *L,
+ const Instruction *R) const {
+ ImmutableCallSite LCS(L);
+ ImmutableCallSite RCS(R);
+
+ assert(LCS && RCS && "Must be calls or invokes!");
+ assert(LCS.isCall() == RCS.isCall() && "Can't compare otherwise!");
+
+ if (int Res =
+ cmpNumbers(LCS.getNumOperandBundles(), RCS.getNumOperandBundles()))
+ return Res;
+
+ for (unsigned i = 0, e = LCS.getNumOperandBundles(); i != e; ++i) {
+ auto OBL = LCS.getOperandBundleAt(i);
+ auto OBR = RCS.getOperandBundleAt(i);
+
+ if (int Res = OBL.getTagName().compare(OBR.getTagName()))
+ return Res;
+
+ if (int Res = cmpNumbers(OBL.Inputs.size(), OBR.Inputs.size()))
+ return Res;
+ }
+
+ return 0;
+}
+
/// Constants comparison:
/// 1. Check whether type of L constant could be losslessly bitcasted to R
/// type.
@@ -941,6 +968,8 @@ int FunctionComparator::cmpOperations(const Instruction *L,
if (int Res =
cmpAttrs(CI->getAttributes(), cast<CallInst>(R)->getAttributes()))
return Res;
+ if (int Res = cmpOperandBundlesSchema(CI, R))
+ return Res;
return cmpRangeMetadata(
CI->getMetadata(LLVMContext::MD_range),
cast<CallInst>(R)->getMetadata(LLVMContext::MD_range));
@@ -952,6 +981,8 @@ int FunctionComparator::cmpOperations(const Instruction *L,
if (int Res =
cmpAttrs(CI->getAttributes(), cast<InvokeInst>(R)->getAttributes()))
return Res;
+ if (int Res = cmpOperandBundlesSchema(CI, R))
+ return Res;
return cmpRangeMetadata(
CI->getMetadata(LLVMContext::MD_range),
cast<InvokeInst>(R)->getMetadata(LLVMContext::MD_range));
diff --git a/llvm/test/Feature/OperandBundles/merge-func.ll b/llvm/test/Feature/OperandBundles/merge-func.ll
new file mode 100644
index 00000000000..aad9262c901
--- /dev/null
+++ b/llvm/test/Feature/OperandBundles/merge-func.ll
@@ -0,0 +1,34 @@
+; RUN: opt -S -mergefunc < %s | FileCheck %s
+
+; Minor note: functions need to be at least three instructions long
+; to be considered by -mergefunc.
+
+declare i32 @foo(...)
+
+define i32 @f() {
+; CHECK-LABEL: @f(
+ entry:
+ %v0 = call i32 (...) @foo(i32 10) [ "foo"(i32 20) ]
+ %v1 = call i32 (...) @foo(i32 10) [ "foo"(i32 20) ]
+ %v2 = call i32 (...) @foo(i32 10) [ "foo"(i32 20) ]
+
+; CHECK: %v0 = call i32 (...) @foo(i32 10) [ "foo"(i32 20) ]
+; CHECK: %v1 = call i32 (...) @foo(i32 10) [ "foo"(i32 20) ]
+; CHECK: %v2 = call i32 (...) @foo(i32 10) [ "foo"(i32 20) ]
+
+ ret i32 %v2
+}
+
+define i32 @g() {
+; CHECK-LABEL: @g(
+ entry:
+ %v0 = call i32 (...) @foo() [ "foo"(i32 10, i32 20) ]
+ %v1 = call i32 (...) @foo() [ "foo"(i32 10, i32 20) ]
+ %v2 = call i32 (...) @foo() [ "foo"(i32 10, i32 20) ]
+
+; CHECK: %v0 = call i32 (...) @foo() [ "foo"(i32 10, i32 20) ]
+; CHECK: %v1 = call i32 (...) @foo() [ "foo"(i32 10, i32 20) ]
+; CHECK: %v2 = call i32 (...) @foo() [ "foo"(i32 10, i32 20) ]
+
+ ret i32 %v2
+}
OpenPOWER on IntegriCloud