| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354 |
- ; RUN: opt < %s -tailcallelim -S | FileCheck %s
- ; Don't turn this into an infinite loop, this is probably the implementation
- ; of fabs and we expect the codegen to lower fabs.
- ; CHECK: @fabs(double %f)
- ; CHECK: call
- ; CHECK: ret
- define double @fabs(double %f) {
- entry:
- %tmp2 = call double @fabs( double %f ) ; <double> [#uses=1]
- ret double %tmp2
- }
- ; Do turn other calls into infinite loops though.
- ; CHECK-LABEL: define double @foo(
- ; CHECK-NOT: call
- ; CHECK: }
- define double @foo(double %f) {
- %t= call double @foo(double %f)
- ret double %t
- }
- ; CHECK-LABEL: define float @fabsf(
- ; CHECK-NOT: call
- ; CHECK: }
- define float @fabsf(float %f) {
- %t= call float @fabsf(float 2.0)
- ret float %t
- }
- declare x86_fp80 @fabsl(x86_fp80 %f)
- ; Don't crash while transforming a function with infinite recursion.
- define i32 @PR22704(i1 %bool) {
- entry:
- br i1 %bool, label %t, label %f
- t:
- %call1 = call i32 @PR22704(i1 1)
- br label %return
- f:
- %call = call i32 @PR22704(i1 1)
- br label %return
- return:
- ret i32 0
- ; CHECK-LABEL: @PR22704(
- ; CHECK: %bool.tr = phi i1 [ %bool, %entry ], [ true, %t ], [ true, %f ]
- ; CHECK: br i1 %bool.tr, label %t, label %f
- }
|