33 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			LLVM
		
	
	
	
			
		
		
	
	
			33 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			LLVM
		
	
	
	
; RUN: opt < %s -loop-reduce -verify
 | 
						|
target triple = "x86_64-apple-darwin10"
 | 
						|
 | 
						|
define void @myquicksort(i8* %a) nounwind ssp {
 | 
						|
entry:
 | 
						|
  br i1 undef, label %loop1, label %return
 | 
						|
 | 
						|
loop1:                                            ; preds = %bb13.loopexit, %entry
 | 
						|
  %indvar419 = phi i64 [ %indvar.next420, %loop2.exit ], [ 0, %entry ]
 | 
						|
  %tmp474 = shl i64 %indvar419, 2
 | 
						|
  %tmp484 = add i64 %tmp474, 4
 | 
						|
  br label %loop2
 | 
						|
 | 
						|
loop2:                                            ; preds = %loop1, %loop2.backedge
 | 
						|
  %indvar414 = phi i64 [ %indvar.next415, %loop2.backedge ], [ 0, %loop1 ]
 | 
						|
  %tmp473 = mul i64 %indvar414, -4
 | 
						|
  %tmp485 = add i64 %tmp484, %tmp473
 | 
						|
  %storemerge4 = getelementptr i8, i8* %a, i64 %tmp485
 | 
						|
  %0 = icmp ugt i8* %storemerge4, %a
 | 
						|
  br i1 false, label %loop2.exit, label %loop2.backedge
 | 
						|
 | 
						|
loop2.backedge:                                   ; preds = %loop2
 | 
						|
  %indvar.next415 = add i64 %indvar414, 1
 | 
						|
  br label %loop2
 | 
						|
 | 
						|
loop2.exit:                                       ; preds = %loop2
 | 
						|
  %indvar.next420 = add i64 %indvar419, 1
 | 
						|
  br i1 undef, label %loop1, label %return
 | 
						|
 | 
						|
return:                                           ; preds = %loop2.exit, %entry
 | 
						|
  ret void
 | 
						|
}
 |