mirror of
https://github.com/RPCSX/llvm.git
synced 2024-12-12 14:17:59 +00:00
919b2376dc
most of the inliner test cases. The inliner involves a bunch of interesting code and tends to be where most of the issues I've seen experimenting with the new PM lie. All of these test cases pass, but I'd like to keep some more thorough coverage here so doing a fairly blanket enabling. There are a handful of interesting tests I've not enabled yet because they're focused on the always inliner, or on functionality that doesn't (yet) exist in the inliner. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@290592 91177308-0d34-0410-b5e6-96231b3b80d8
36 lines
1.2 KiB
LLVM
36 lines
1.2 KiB
LLVM
; RUN: opt < %s -S -inline -inline-threshold=20 | FileCheck %s
|
|
; RUN: opt < %s -S -passes='cgscc(inline)' -inline-threshold=20 | FileCheck %s
|
|
; Check that we don't drop FastMathFlag when estimating inlining profitability.
|
|
;
|
|
; In this test we should inline 'foo' to 'boo', because it'll fold to a
|
|
; constant.
|
|
|
|
target datalayout = "e-m:o-i64:64-f80:128-n8:16:32:64-S128"
|
|
|
|
define float @foo(float* %a, float %b) {
|
|
entry:
|
|
%a0 = load float, float* %a, align 4
|
|
%mul = fmul fast float %a0, %b
|
|
%tobool = fcmp une float %mul, 0.000000e+00
|
|
br i1 %tobool, label %if.then, label %if.end
|
|
|
|
if.then: ; preds = %entry
|
|
%a1 = load float, float* %a, align 8
|
|
%arrayidx1 = getelementptr inbounds float, float* %a, i64 1
|
|
%a2 = load float, float* %arrayidx1, align 4
|
|
%add = fadd fast float %a1, %a2
|
|
br label %if.end
|
|
|
|
if.end: ; preds = %if.then, %entry
|
|
%storemerge = phi float [ %add, %if.then ], [ 1.000000e+00, %entry ]
|
|
ret float %storemerge
|
|
}
|
|
|
|
; CHECK-LABEL: @boo
|
|
; CHECK-NOT: call float @foo
|
|
define float @boo(float* %a) {
|
|
entry:
|
|
%call = call float @foo(float* %a, float 0.000000e+00)
|
|
ret float %call
|
|
}
|