Optimize DAGCombiner's worklist processing. Previously it started
[oota-llvm.git] / test / CodeGen / X86 / loop-hoist.ll
1 ; RUN: llvm-as < %s | \
2 ; RUN:   llc -relocation-model=dynamic-no-pic -mtriple=i686-apple-darwin8.7.2 |\
3 ; RUN:   grep L_Arr.non_lazy_ptr
4 ; RUN: llvm-as < %s | \
5 ; RUN:   llc -relocation-model=dynamic-no-pic -mtriple=i686-apple-darwin8.7.2 |\
6 ; RUN:   %prcontext L_Arr.non_lazy_ptr 1 | grep {4(%esp)}
7
8 @Arr = external global [0 x i32]                ; <[0 x i32]*> [#uses=1]
9
10 define void @foo(i32 %N.in, i32 %x) {
11 entry:
12         %N = bitcast i32 %N.in to i32           ; <i32> [#uses=1]
13         br label %cond_true
14
15 cond_true:              ; preds = %cond_true, %entry
16         %indvar = phi i32 [ %x, %entry ], [ %indvar.next, %cond_true ]          ; <i32> [#uses=2]
17         %i.0.0 = bitcast i32 %indvar to i32             ; <i32> [#uses=2]
18         %tmp = getelementptr [0 x i32]* @Arr, i32 0, i32 %i.0.0         ; <i32*> [#uses=1]
19         store i32 %i.0.0, i32* %tmp
20         %indvar.next = add i32 %indvar, 1               ; <i32> [#uses=2]
21         %exitcond = icmp eq i32 %indvar.next, %N                ; <i1> [#uses=1]
22         br i1 %exitcond, label %return, label %cond_true
23
24 return:         ; preds = %cond_true
25         ret void
26 }