mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-09-27 16:17:17 +00:00
[LoopUnroll] Use undef for phis with no value live
We would create a phi node with a zero initialized operand instead of undef in the case where no value was originally available. This was problematic for x86_mmx which has no null value. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@241143 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -86,7 +86,7 @@ static void ConnectProlog(Loop *L, Value *BECount, unsigned Count,
|
|||||||
if (L->contains(PN)) {
|
if (L->contains(PN)) {
|
||||||
NewPN->addIncoming(PN->getIncomingValueForBlock(NewPH), OrigPH);
|
NewPN->addIncoming(PN->getIncomingValueForBlock(NewPH), OrigPH);
|
||||||
} else {
|
} else {
|
||||||
NewPN->addIncoming(Constant::getNullValue(PN->getType()), OrigPH);
|
NewPN->addIncoming(UndefValue::get(PN->getType()), OrigPH);
|
||||||
}
|
}
|
||||||
|
|
||||||
Value *V = PN->getIncomingValueForBlock(Latch);
|
Value *V = PN->getIncomingValueForBlock(Latch);
|
||||||
|
24
test/Transforms/LoopUnroll/X86/mmx.ll
Normal file
24
test/Transforms/LoopUnroll/X86/mmx.ll
Normal file
@@ -0,0 +1,24 @@
|
|||||||
|
; 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_unr:.*]] = phi x86_mmx [ undef,
|
||||||
|
; CHECK: %[[ret_ph:.*]] = phi x86_mmx [ undef,
|
||||||
|
; CHECK: %[[ret:.*]] = phi x86_mmx [ %[[ret_unr]], {{.*}} ], [ %[[ret_ph]]
|
||||||
|
; CHECK: ret x86_mmx %[[ret]]
|
||||||
|
ret x86_mmx %ret
|
||||||
|
}
|
||||||
|
|
||||||
|
attributes #0 = { "target-cpu"="x86-64" }
|
Reference in New Issue
Block a user