1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2024-10-30 23:42:52 +01:00
llvm-mirror/test/Regression/Transforms/SCCP/calltest.ll
Chris Lattner 486436b5ad New testcase
llvm-svn: 12920
2004-04-13 19:43:33 +00:00

25 lines
526 B
LLVM

; RUN: llvm-as < %s | opt -sccp -adce -simplifycfg | llvm-dis | not grep br
; No matter how hard you try, sqrt(1.0) is always 1.0. This allows the
; optimizer to delete this loop.
declare double %sqrt(double)
double %test(uint %param) {
entry:
br label %Loop
Loop:
%I2 = phi uint [ 0, %entry ], [ %I3, %Loop ]
%V = phi double [ 1.0, %entry], [ %V2, %Loop ]
%V2 = call double %sqrt(double %V)
%I3 = add uint %I2, 1
%tmp.7 = setne uint %I3, %param
br bool %tmp.7, label %Loop, label %Exit
Exit:
ret double %V
}