[llvm] r327207 - [PartialInlining] Use isInlineViable to detect constructs preventing inlining.
Florian Hahn via llvm-commits
llvm-commits at lists.llvm.org
Sat Mar 10 06:53:44 PST 2018
Author: fhahn
Date: Sat Mar 10 06:53:44 2018
New Revision: 327207
URL: http://llvm.org/viewvc/llvm-project?rev=327207&view=rev
Log:
[PartialInlining] Use isInlineViable to detect constructs preventing inlining.
Use isInlineViable to prevent inlining of functions with non-inlinable
constructs, in case cost analysis is skipped.
Reviewers: efriedma, sfertile, davide, davidxl
Reviewed By: efriedma
Differential Revision: https://reviews.llvm.org/D42846
Added:
llvm/trunk/test/Transforms/CodeExtractor/PartialInlineNotViable.ll
Modified:
llvm/trunk/lib/Transforms/IPO/PartialInlining.cpp
Modified: llvm/trunk/lib/Transforms/IPO/PartialInlining.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Transforms/IPO/PartialInlining.cpp?rev=327207&r1=327206&r2=327207&view=diff
==============================================================================
--- llvm/trunk/lib/Transforms/IPO/PartialInlining.cpp (original)
+++ llvm/trunk/lib/Transforms/IPO/PartialInlining.cpp Sat Mar 10 06:53:44 2018
@@ -769,13 +769,13 @@ bool PartialInlinerImpl::shouldPartialIn
BlockFrequency WeightedOutliningRcost) {
using namespace ore;
- if (SkipCostAnalysis)
- return true;
-
Instruction *Call = CS.getInstruction();
Function *Callee = CS.getCalledFunction();
assert(Callee == Cloner.ClonedFunc);
+ if (SkipCostAnalysis)
+ return isInlineViable(*Callee);
+
Function *Caller = CS.getCaller();
auto &CalleeTTI = (*GetTTI)(*Callee);
auto &ORE = (*GetORE)(*Caller);
Added: llvm/trunk/test/Transforms/CodeExtractor/PartialInlineNotViable.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Transforms/CodeExtractor/PartialInlineNotViable.ll?rev=327207&view=auto
==============================================================================
--- llvm/trunk/test/Transforms/CodeExtractor/PartialInlineNotViable.ll (added)
+++ llvm/trunk/test/Transforms/CodeExtractor/PartialInlineNotViable.ll Sat Mar 10 06:53:44 2018
@@ -0,0 +1,63 @@
+; RUN: opt < %s -partial-inliner -skip-partial-inlining-cost-analysis -S | FileCheck %s
+;
+
+define i32 @callee_indr_branch(i32 %v) {
+entry:
+ %cmp = icmp sgt i32 %v, 2000
+ %addr = select i1 %cmp, i8* blockaddress(@callee_indr_branch, %if.then), i8* blockaddress(@callee_indr_branch, %if.end)
+ indirectbr i8* %addr, [ label %if.then, label %if.end]
+
+if.then: ; preds = %entry
+ %mul = mul nsw i32 %v, 10
+ br label %if.then2
+
+if.then2:
+ %sub = sub i32 %v, 10
+ br label %if.end
+
+if.end: ; preds = %if.then, %entry
+ %v2 = phi i32 [ %v, %entry ], [ %mul, %if.then2 ]
+ %add = add nsw i32 %v2, 200
+ ret i32 %add
+}
+
+declare void @use_fp(i8 *)
+declare void @llvm.localescape(...)
+declare i8* @llvm.frameaddress(i32)
+declare i8* @llvm.localrecover(i8*, i8*, i32)
+
+
+
+define i32 @callee_frameescape(i32 %v) {
+entry:
+ %a = alloca i32
+ call void (...) @llvm.localescape(i32* %a)
+ %cmp = icmp sgt i32 %v, 2000
+ br i1 %cmp, label %if.then, label %if.end
+
+if.then: ; preds = %entry
+ %mul = mul nsw i32 %v, 10
+ br label %if.then2
+
+if.then2:
+ %sub = sub i32 %v, 10
+ br label %if.end
+
+if.end: ; preds = %if.then, %entry
+ %v2 = phi i32 [ %v, %entry ], [ %mul, %if.then2 ]
+ %add = add nsw i32 %v2, 200
+ ret i32 %add
+}
+
+
+; CHECK-LABEL: @caller
+; CHECK: %r1 = call i32 @callee_indr_branch(i32 %v)
+; CHECK-NEXT: %r2 = call i32 @callee_frameescape(i32 %v)
+define i32 @caller(i32 %v) {
+entry:
+ %r1 = call i32 @callee_indr_branch(i32 %v)
+ %r2 = call i32 @callee_frameescape(i32 %v)
+ %res = add i32 %r1, %r2
+ ret i32 %res
+}
+
More information about the llvm-commits
mailing list