176 lines
		
	
	
		
			5.5 KiB
		
	
	
	
		
			LLVM
		
	
	
	
			
		
		
	
	
			176 lines
		
	
	
		
			5.5 KiB
		
	
	
	
		
			LLVM
		
	
	
	
; RUN: llc < %s -x86-early-ifcvt -stress-early-ifcvt | FileCheck %s
 | 
						|
target triple = "x86_64-apple-macosx10.8.0"
 | 
						|
 | 
						|
; CHECK: mm2
 | 
						|
define i32 @mm2(i32* nocapture %p, i32 %n) nounwind uwtable readonly ssp {
 | 
						|
entry:
 | 
						|
  br label %do.body
 | 
						|
 | 
						|
; CHECK: do.body
 | 
						|
; Loop body has no branches before the backedge.
 | 
						|
; CHECK-NOT: LBB
 | 
						|
do.body:
 | 
						|
  %max.0 = phi i32 [ 0, %entry ], [ %max.1, %do.cond ]
 | 
						|
  %min.0 = phi i32 [ 0, %entry ], [ %min.1, %do.cond ]
 | 
						|
  %n.addr.0 = phi i32 [ %n, %entry ], [ %dec, %do.cond ]
 | 
						|
  %p.addr.0 = phi i32* [ %p, %entry ], [ %incdec.ptr, %do.cond ]
 | 
						|
  %incdec.ptr = getelementptr inbounds i32, i32* %p.addr.0, i64 1
 | 
						|
  %0 = load i32, i32* %p.addr.0, align 4
 | 
						|
  %cmp = icmp sgt i32 %0, %max.0
 | 
						|
  br i1 %cmp, label %do.cond, label %if.else
 | 
						|
 | 
						|
if.else:
 | 
						|
  %cmp1 = icmp slt i32 %0, %min.0
 | 
						|
  %.min.0 = select i1 %cmp1, i32 %0, i32 %min.0
 | 
						|
  br label %do.cond
 | 
						|
 | 
						|
do.cond:
 | 
						|
  %max.1 = phi i32 [ %0, %do.body ], [ %max.0, %if.else ]
 | 
						|
  %min.1 = phi i32 [ %min.0, %do.body ], [ %.min.0, %if.else ]
 | 
						|
; CHECK: decl %esi
 | 
						|
; CHECK: jne LBB
 | 
						|
  %dec = add i32 %n.addr.0, -1
 | 
						|
  %tobool = icmp eq i32 %dec, 0
 | 
						|
  br i1 %tobool, label %do.end, label %do.body
 | 
						|
 | 
						|
do.end:
 | 
						|
  %sub = sub nsw i32 %max.1, %min.1
 | 
						|
  ret i32 %sub
 | 
						|
}
 | 
						|
 | 
						|
; CHECK: multipreds
 | 
						|
; Deal with alternative tail predecessors
 | 
						|
; CHECK-NOT: LBB
 | 
						|
; CHECK: cmov
 | 
						|
; CHECK-NOT: LBB
 | 
						|
; CHECK: cmov
 | 
						|
; CHECK-NOT: LBB
 | 
						|
; CHECK: fprintf
 | 
						|
 | 
						|
define void @multipreds(i32 %sw) nounwind uwtable ssp {
 | 
						|
entry:
 | 
						|
  switch i32 %sw, label %if.then29 [
 | 
						|
    i32 0, label %if.then37
 | 
						|
    i32 127, label %if.end41
 | 
						|
  ]
 | 
						|
 | 
						|
if.then29:
 | 
						|
  br label %if.end41
 | 
						|
 | 
						|
if.then37:
 | 
						|
  br label %if.end41
 | 
						|
 | 
						|
if.end41:
 | 
						|
  %exit_status.0 = phi i32 [ 2, %if.then29 ], [ 0, %if.then37 ], [ 66, %entry ]
 | 
						|
  call void (...) @fprintf(i32 %exit_status.0) nounwind
 | 
						|
  unreachable
 | 
						|
}
 | 
						|
 | 
						|
declare void @fprintf(...) nounwind
 | 
						|
 | 
						|
; CHECK: BZ2_decompress
 | 
						|
; This test case contains irreducible control flow, so MachineLoopInfo doesn't
 | 
						|
; recognize the cycle in the CFG. This would confuse MachineTraceMetrics.
 | 
						|
define void @BZ2_decompress(i8* %s) nounwind ssp {
 | 
						|
entry:
 | 
						|
  switch i32 undef, label %sw.default [
 | 
						|
    i32 39, label %if.end.sw.bb2050_crit_edge
 | 
						|
    i32 36, label %sw.bb1788
 | 
						|
    i32 37, label %if.end.sw.bb1855_crit_edge
 | 
						|
    i32 40, label %sw.bb2409
 | 
						|
    i32 38, label %sw.bb1983
 | 
						|
    i32 44, label %if.end.sw.bb3058_crit_edge
 | 
						|
  ]
 | 
						|
 | 
						|
if.end.sw.bb3058_crit_edge:                       ; preds = %entry
 | 
						|
  br label %save_state_and_return
 | 
						|
 | 
						|
if.end.sw.bb1855_crit_edge:                       ; preds = %entry
 | 
						|
  br label %save_state_and_return
 | 
						|
 | 
						|
if.end.sw.bb2050_crit_edge:                       ; preds = %entry
 | 
						|
  br label %sw.bb2050
 | 
						|
 | 
						|
sw.bb1788:                                        ; preds = %entry
 | 
						|
  br label %save_state_and_return
 | 
						|
 | 
						|
sw.bb1983:                                        ; preds = %entry
 | 
						|
  br i1 undef, label %save_state_and_return, label %if.then1990
 | 
						|
 | 
						|
if.then1990:                                      ; preds = %sw.bb1983
 | 
						|
  br label %while.body2038
 | 
						|
 | 
						|
while.body2038:                                   ; preds = %sw.bb2050, %if.then1990
 | 
						|
  %groupPos.8 = phi i32 [ 0, %if.then1990 ], [ %groupPos.9, %sw.bb2050 ]
 | 
						|
  br i1 undef, label %save_state_and_return, label %if.end2042
 | 
						|
 | 
						|
if.end2042:                                       ; preds = %while.body2038
 | 
						|
  br i1 undef, label %if.end2048, label %while.end2104
 | 
						|
 | 
						|
if.end2048:                                       ; preds = %if.end2042
 | 
						|
  %bsLive2054.pre = getelementptr inbounds i8, i8* %s, i32 8
 | 
						|
  br label %sw.bb2050
 | 
						|
 | 
						|
sw.bb2050:                                        ; preds = %if.end2048, %if.end.sw.bb2050_crit_edge
 | 
						|
  %groupPos.9 = phi i32 [ 0, %if.end.sw.bb2050_crit_edge ], [ %groupPos.8, %if.end2048 ]
 | 
						|
  %and2064 = and i32 undef, 1
 | 
						|
  br label %while.body2038
 | 
						|
 | 
						|
while.end2104:                                    ; preds = %if.end2042
 | 
						|
  br i1 undef, label %save_state_and_return, label %if.end2117
 | 
						|
 | 
						|
if.end2117:                                       ; preds = %while.end2104
 | 
						|
  br i1 undef, label %while.body2161.lr.ph, label %while.body2145.lr.ph
 | 
						|
 | 
						|
while.body2145.lr.ph:                             ; preds = %if.end2117
 | 
						|
  br label %save_state_and_return
 | 
						|
 | 
						|
while.body2161.lr.ph:                             ; preds = %if.end2117
 | 
						|
  br label %save_state_and_return
 | 
						|
 | 
						|
sw.bb2409:                                        ; preds = %entry
 | 
						|
  br label %save_state_and_return
 | 
						|
 | 
						|
sw.default:                                       ; preds = %entry
 | 
						|
  call void @BZ2_bz__AssertH__fail() nounwind
 | 
						|
  br label %save_state_and_return
 | 
						|
 | 
						|
save_state_and_return:
 | 
						|
  %groupPos.14 = phi i32 [ 0, %sw.default ], [ %groupPos.8, %while.body2038 ], [ %groupPos.8, %while.end2104 ], [ 0, %if.end.sw.bb3058_crit_edge ], [ 0, %if.end.sw.bb1855_crit_edge ], [ %groupPos.8, %while.body2161.lr.ph ], [ %groupPos.8, %while.body2145.lr.ph ], [ 0, %sw.bb2409 ], [ 0, %sw.bb1788 ], [ 0, %sw.bb1983 ]
 | 
						|
  store i32 %groupPos.14, i32* undef, align 4
 | 
						|
  ret void
 | 
						|
}
 | 
						|
 | 
						|
declare void @BZ2_bz__AssertH__fail()
 | 
						|
 | 
						|
; Make sure we don't speculate on div/idiv instructions
 | 
						|
; CHECK: test_idiv
 | 
						|
; CHECK-NOT: cmov
 | 
						|
define i32 @test_idiv(i32 %a, i32 %b) nounwind uwtable readnone ssp {
 | 
						|
  %1 = icmp eq i32 %b, 0
 | 
						|
  br i1 %1, label %4, label %2
 | 
						|
 | 
						|
; <label>:2                                       ; preds = %0
 | 
						|
  %3 = sdiv i32 %a, %b
 | 
						|
  br label %4
 | 
						|
 | 
						|
; <label>:4                                       ; preds = %0, %2
 | 
						|
  %5 = phi i32 [ %3, %2 ], [ %a, %0 ]
 | 
						|
  ret i32 %5
 | 
						|
}
 | 
						|
 | 
						|
; CHECK: test_div
 | 
						|
; CHECK-NOT: cmov
 | 
						|
define i32 @test_div(i32 %a, i32 %b) nounwind uwtable readnone ssp {
 | 
						|
  %1 = icmp eq i32 %b, 0
 | 
						|
  br i1 %1, label %4, label %2
 | 
						|
 | 
						|
; <label>:2                                       ; preds = %0
 | 
						|
  %3 = udiv i32 %a, %b
 | 
						|
  br label %4
 | 
						|
 | 
						|
; <label>:4                                       ; preds = %0, %2
 | 
						|
  %5 = phi i32 [ %3, %2 ], [ %a, %0 ]
 | 
						|
  ret i32 %5
 | 
						|
}
 |