1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2024-11-25 04:02:41 +01:00
llvm-mirror/test/Transforms/Inline/vector-no-bonus.ll
Easwaran Raman e2c4ce9596 [Inliner] Do not apply any bonus for cold callsites.
Summary:
Inlining threshold is increased by application of bonuses when the
callee has a single reachable basic block or is rich in vector
instructions. Similarly, inlining cost is reduced by applying a large
bonus when the last call to a static function is considered for
inlining. This patch disables the application of these bonuses when the
callsite or the callee is cold. The intention here is to prevent a large
cold callsite from being inlined to a non-cold caller that could prevent
the caller from being inlined. This is especially important when the
cold callsite is a last call to a static since the associated bonus is
very high.

Reviewers: chandlerc, davidxl

Subscribers: danielcdh, llvm-commits

Differential Revision: https://reviews.llvm.org/D35823

llvm-svn: 309441
2017-07-28 21:47:36 +00:00

48 lines
1.4 KiB
LLVM

; The code in this test is very similar to vector-bonus.ll except for
; the fact that the call to bar is cold thereby preventing the application of
; the vector bonus.
; RUN: opt < %s -inline -inline-threshold=35 -S | FileCheck %s
; RUN: opt < %s -passes='cgscc(inline)' -inline-threshold=35 -S | FileCheck %s
define i32 @bar(<4 x i32> %v, i32 %i) #0 {
entry:
%cmp = icmp sgt i32 %i, 4
br i1 %cmp, label %if.then, label %if.else
if.then: ; preds = %entry
%mul1 = mul nsw i32 %i, %i
br label %return
if.else: ; preds = %entry
%add1 = add nsw i32 %i, %i
%add2 = add nsw i32 %i, %i
%add3 = add nsw i32 %i, %i
%add4 = add nsw i32 %i, %i
%add5 = add nsw i32 %i, %i
%add6 = add nsw i32 %i, %i
%vecext = extractelement <4 x i32> %v, i32 0
%vecext7 = extractelement <4 x i32> %v, i32 1
%add7 = add nsw i32 %vecext, %vecext7
br label %return
return: ; preds = %if.else, %if.then
%retval.0 = phi i32 [ %mul1, %if.then ], [ %add7, %if.else ]
ret i32 %retval.0
}
define i32 @foo(<4 x i32> %v, i32 %a) #1 {
; CHECK-LABEL: @foo(
; CHECK-NOT: call i32 @bar
; CHECK: ret
entry:
%cmp = icmp eq i32 %a, 0
br i1 %cmp, label %callbb, label %ret
callbb:
%call = call i32 @bar(<4 x i32> %v, i32 %a)
br label %ret
ret:
%call1 = phi i32 [%call, %callbb], [0, %entry]
ret i32 %call1
}