1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2025-02-01 13:11:39 +01:00
llvm-mirror/test/Transforms/LoopUnroll/peel-loop-irreducible.ll
Michael Kuperstein cac07a241c [LoopUnroll] Don't peel loops where the latch isn't the exiting block
Peeling assumed this doesn't happen, but didn't check it.
This fixes PR32178.

Differential Revision: https://reviews.llvm.org/D30757

llvm-svn: 297993
2017-03-16 21:07:48 +00:00

37 lines
951 B
LLVM

; RUN: opt < %s -S -loop-unroll -unroll-force-peel-count=1 | FileCheck %s
; Check we don't peel loops where the latch is not the exiting block.
; CHECK-LABEL: @invariant_backedge_irreducible
; CHECK: entry:
; CHECK: br label %header
; CHECK-NOT: peel
; CHECK: header:
; CHECK: br i1 {{.*}} label %latch, label %exiting
; CHECK: latch:
; CHECK: br i1 {{.*}} label %header, label %exiting
; CHECK: exiting:
; CHECK: br i1 {{.*}} label %latch, label %exit
define i32 @invariant_backedge_irreducible(i32 %a, i32 %b) {
entry:
br label %header
header:
%i = phi i32 [ 0, %entry ], [ %inc, %latch ]
%cmp.phi = phi i1 [ false, %entry ], [ %cmp, %latch ]
br i1 %cmp.phi, label %latch, label %exiting
latch:
%inc = add i32 %i, 1
%cmp = icmp slt i32 %i, 1000
br i1 %cmp, label %header, label %exiting
exiting:
%cmp.exiting = phi i1 [ %cmp.phi, %header ], [ %cmp, %latch ]
br i1 %cmp.exiting, label %latch, label %exit
exit:
ret i32 0
}