1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2024-10-24 13:33:37 +02:00
llvm-mirror/test/Transforms/LoopUnroll/X86/mmx.ll
David L Kreitzer 01b0be98a9 Adds the ability to use an epilog remainder loop during loop unrolling and makes
this the default behavior.

Patch by Evgeny Stupachenko (evstupac@gmail.com).

Differential Revision: http://reviews.llvm.org/D18158

llvm-svn: 265388
2016-04-05 12:19:35 +00:00

25 lines
826 B
LLVM

; RUN: opt < %s -S -loop-unroll | FileCheck %s
target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
target triple = "x86_64-unknown-linux-gnu"
define x86_mmx @f() #0 {
entry:
br label %for.body
for.body: ; preds = %for.body, %entry
%phi = phi i32 [ 1, %entry ], [ %add, %for.body ]
%add = add i32 %phi, 1
%cmp = icmp eq i32 %phi, 0
br i1 %cmp, label %exit, label %for.body
exit: ; preds = %for.body
%ret = phi x86_mmx [ undef, %for.body ]
; CHECK: %[[ret_ph:.*]] = phi x86_mmx [ undef, %entry
; CHECK: %[[ret_ph1:.*]] = phi x86_mmx [ undef,
; CHECK: %[[ret:.*]] = phi x86_mmx [ %[[ret_ph]], {{.*}} ], [ %[[ret_ph1]],
; CHECK: ret x86_mmx %[[ret]]
ret x86_mmx %ret
}
attributes #0 = { "target-cpu"="x86-64" }