mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-13 20:32:21 +00:00
[IndVarSimplify] Widen loop unsigned compares.
This patch extends r217953 to handle unsigned comparison. Phabricator revision: http://reviews.llvm.org/D5526 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@218659 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
4abb04a65c
commit
ecea7ba518
@ -936,12 +936,8 @@ bool WidenIV::WidenLoopCompare(NarrowIVDefUse DU) {
|
||||
if (!Cmp)
|
||||
return false;
|
||||
|
||||
// Must be a signed compare.
|
||||
if (!CmpInst::isSigned(Cmp->getPredicate()))
|
||||
return false;
|
||||
|
||||
// Must be a signed IV user.
|
||||
if (!IsSigned)
|
||||
// Sign of IV user and compare must match.
|
||||
if (IsSigned != CmpInst::isSigned(Cmp->getPredicate()))
|
||||
return false;
|
||||
|
||||
Value *Op = Cmp->getOperand(Cmp->getOperand(0) == DU.NarrowDef ? 1 : 0);
|
||||
|
@ -162,3 +162,31 @@ for.body:
|
||||
for.end:
|
||||
ret i32 0
|
||||
}
|
||||
|
||||
; CHECK-LABEL: @test5
|
||||
; CHECK: zext i32 %b
|
||||
; CHECK: for.cond:
|
||||
; CHECK: phi i64
|
||||
; CHECK: icmp ule i64
|
||||
|
||||
define i32 @test5(i32* %a, i32 %b) {
|
||||
entry:
|
||||
br label %for.cond
|
||||
|
||||
for.cond:
|
||||
%sum.0 = phi i32 [ 0, %entry ], [ %add, %for.body ]
|
||||
%i.0 = phi i32 [ 0, %entry ], [ %inc, %for.body ]
|
||||
%cmp = icmp ule i32 %i.0, %b
|
||||
br i1 %cmp, label %for.body, label %for.end
|
||||
|
||||
for.body:
|
||||
%idxprom = zext i32 %i.0 to i64
|
||||
%arrayidx = getelementptr inbounds i32* %a, i64 %idxprom
|
||||
%0 = load i32* %arrayidx, align 4
|
||||
%add = add nsw i32 %sum.0, %0
|
||||
%inc = add nsw i32 %i.0, 1
|
||||
br label %for.cond
|
||||
|
||||
for.end:
|
||||
ret i32 %sum.0
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user