1 ; RUN: opt < %s -loop-reduce -verify
2 target triple = "x86_64-apple-darwin10"
4 define void @myquicksort(ptr %a) nounwind ssp {
6 br i1 undef, label %loop1, label %return
8 loop1: ; preds = %bb13.loopexit, %entry
9 %indvar419 = phi i64 [ %indvar.next420, %loop2.exit ], [ 0, %entry ]
10 %tmp474 = shl i64 %indvar419, 2
11 %tmp484 = add i64 %tmp474, 4
14 loop2: ; preds = %loop1, %loop2.backedge
15 %indvar414 = phi i64 [ %indvar.next415, %loop2.backedge ], [ 0, %loop1 ]
16 %tmp473 = mul i64 %indvar414, -4
17 %tmp485 = add i64 %tmp484, %tmp473
18 %storemerge4 = getelementptr i8, ptr %a, i64 %tmp485
19 %0 = icmp ugt ptr %storemerge4, %a
20 br i1 false, label %loop2.exit, label %loop2.backedge
22 loop2.backedge: ; preds = %loop2
23 %indvar.next415 = add i64 %indvar414, 1
26 loop2.exit: ; preds = %loop2
27 %indvar.next420 = add i64 %indvar419, 1
28 br i1 undef, label %loop1, label %return
30 return: ; preds = %loop2.exit, %entry