mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-10-31 16:02:52 +01:00
f20746afd1
This conversion was done with the following bash script: find test/Transforms -name "*.ll" | \ while read NAME; do echo "$NAME" if ! grep -q "^; *RUN: *llc" $NAME; then TEMP=`mktemp -t temp` cp $NAME $TEMP sed -n "s/^define [^@]*@\([A-Za-z0-9_]*\)(.*$/\1/p" < $NAME | \ while read FUNC; do sed -i '' "s/;\(.*\)\([A-Za-z0-9_]*\):\( *\)define\([^@]*\)@$FUNC\([( ]*\)\$/;\1\2-LABEL:\3define\4@$FUNC(/g" $TEMP done mv $TEMP $NAME fi done llvm-svn: 186269
34 lines
787 B
LLVM
34 lines
787 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-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)
|