diff options
author | Evgeny Stupachenko <evstupac@gmail.com> | 2017-03-04 05:20:02 +0000 |
---|---|---|
committer | Evgeny Stupachenko <evstupac@gmail.com> | 2017-03-04 05:20:02 +0000 |
commit | e4b0813d62f82ed7e4f09408279fe4649ef4a277 (patch) | |
tree | dfe848f72e6d850d5c1a3f3426ff2767a9b96768 /llvm/test/Transforms/LoopUnroll/epilog_const_phi.ll | |
parent | 392da4bc49b7d7dfe42bfe530b7ca73a5688e75b (diff) | |
download | bcm5719-llvm-e4b0813d62f82ed7e4f09408279fe4649ef4a277.tar.gz bcm5719-llvm-e4b0813d62f82ed7e4f09408279fe4649ef4a277.zip |
Add test missed in r296770.
Differential Revision: http://reviews.llvm.org/D27004
From: Evgeny Stupachenko <evstupac@gmail.com>
llvm-svn: 296962
Diffstat (limited to 'llvm/test/Transforms/LoopUnroll/epilog_const_phi.ll')
-rw-r--r-- | llvm/test/Transforms/LoopUnroll/epilog_const_phi.ll | 65 |
1 files changed, 65 insertions, 0 deletions
diff --git a/llvm/test/Transforms/LoopUnroll/epilog_const_phi.ll b/llvm/test/Transforms/LoopUnroll/epilog_const_phi.ll new file mode 100644 index 00000000000..22e52576094 --- /dev/null +++ b/llvm/test/Transforms/LoopUnroll/epilog_const_phi.ll @@ -0,0 +1,65 @@ +; RUN: opt -S -loop-unroll -unroll-runtime < %s | FileCheck %s + +; Epilog unroll allows to keep PHI constant value. +; For the test this means that after unroll XOR could be deleted. +; Check that we do epilogue reminder here. + +; CHECK-LABEL: const_phi_val +; CHECK: for.body.epil + +; Function Attrs: norecurse nounwind uwtable +define void @const_phi_val(i32 %i0, i32* nocapture %a) { +entry: + %cmp6 = icmp slt i32 %i0, 1000 + br i1 %cmp6, label %for.body.preheader, label %for.end + +for.body.preheader: ; preds = %entry + %tmp = sext i32 %i0 to i64 + br label %for.body + +for.body: ; preds = %for.body, %for.body.preheader + %indvars.iv = phi i64 [ %tmp, %for.body.preheader ], [ %indvars.iv.next, %for.body ] + %s.08 = phi i32 [ 0, %for.body.preheader ], [ %xor, %for.body ] + %arrayidx = getelementptr inbounds i32, i32* %a, i64 %indvars.iv + store i32 %s.08, i32* %arrayidx, align 4 + %xor = xor i32 %s.08, 1 + %indvars.iv.next = add nsw i64 %indvars.iv, 1 + %exitcond = icmp eq i64 %indvars.iv.next, 1000 + br i1 %exitcond, label %for.end.loopexit, label %for.body + +for.end.loopexit: ; preds = %for.body + br label %for.end + +for.end: ; preds = %for.end.loopexit, %entry + ret void +} + +; When there is no phi with const coming from preheader, +; there is no need to do epilogue unrolling. + +; CHECK-LABEL: var_phi_val +; CHECK: for.body.prol + +; Function Attrs: norecurse nounwind uwtable +define void @var_phi_val(i32 %i0, i32* nocapture %a) { +entry: + %cmp6 = icmp slt i32 %i0, 1000 + br i1 %cmp6, label %for.body.preheader, label %for.end + +for.body.preheader: ; preds = %entry + %tmp = sext i32 %i0 to i64 + br label %for.body + +for.body: ; preds = %for.body, %for.body.preheader + %indvars.iv = phi i64 [ %tmp, %for.body.preheader ], [ %indvars.iv.next, %for.body ] + %arrayidx = getelementptr inbounds i32, i32* %a, i64 %indvars.iv + %indvars.iv.next = add nsw i64 %indvars.iv, 1 + %exitcond = icmp eq i64 %indvars.iv.next, 1000 + br i1 %exitcond, label %for.end.loopexit, label %for.body + +for.end.loopexit: ; preds = %for.body + br label %for.end + +for.end: ; preds = %for.end.loopexit, %entry + ret void +} |