mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-24 06:30:19 +00:00
ea25b48af3
callee is expected to be expanded to something else by codegen, so that normal infinitely recursive calls are still transformed. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@101468 91177308-0d34-0410-b5e6-96231b3b80d8
35 lines
804 B
LLVM
35 lines
804 B
LLVM
; 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: define double @foo
|
|
; CHECK-NOT: call
|
|
; CHECK: }
|
|
define double @foo(double %f) {
|
|
%t= call double @foo(double %f)
|
|
ret double %t
|
|
}
|
|
|
|
; CHECK: define float @fabsf
|
|
; CHECK-NOT: call
|
|
; CHECK: }
|
|
define float @fabsf(float %f) {
|
|
%t= call float @fabsf(float 2.0)
|
|
ret float %t
|
|
}
|
|
|
|
declare float @fabsf(float %f)
|
|
declare x86_fp80 @fabsl(x86_fp80 %f)
|