mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-18 13:34:04 +00:00
allow LazyValueInfo::getEdgeValue() to reason about multiple edges from the same switch instruction by doing union of ranges (which may still be conservative, but it's more aggressive than before)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@157071 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
3e96531186
commit
90255a8517
@ -862,23 +862,18 @@ bool LazyValueInfoCache::getEdgeValue(Value *Val, BasicBlock *BBFrom,
|
||||
return true;
|
||||
}
|
||||
|
||||
// We only know something if there is exactly one value that goes from
|
||||
// BBFrom to BBTo.
|
||||
unsigned NumEdges = 0;
|
||||
ConstantInt *EdgeVal = 0;
|
||||
unsigned BitWidth = Val->getType()->getIntegerBitWidth();
|
||||
ConstantRange EdgesVals(BitWidth, false/*isFullSet*/);
|
||||
for (SwitchInst::CaseIt i = SI->case_begin(), e = SI->case_end();
|
||||
i != e; ++i) {
|
||||
if (i.getCaseSuccessor() != BBTo) continue;
|
||||
if (NumEdges++) break;
|
||||
EdgeVal = i.getCaseValue();
|
||||
ConstantRange EdgeVal(i.getCaseValue()->getValue());
|
||||
EdgesVals = EdgesVals.unionWith(EdgeVal);
|
||||
}
|
||||
assert(EdgeVal && "Missing successor?");
|
||||
if (NumEdges == 1) {
|
||||
Result = LVILatticeVal::get(EdgeVal);
|
||||
Result = LVILatticeVal::getRange(EdgesVals);
|
||||
return true;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// Otherwise see if the value is known in the block.
|
||||
if (hasBlockValue(Val, BBFrom)) {
|
||||
|
@ -70,3 +70,31 @@ if.then4:
|
||||
if.end8:
|
||||
ret i32 4
|
||||
}
|
||||
|
||||
; CHECK: @test4
|
||||
define i32 @test4(i32 %c) nounwind {
|
||||
switch i32 %c, label %sw.default [
|
||||
i32 1, label %sw.bb
|
||||
i32 2, label %sw.bb
|
||||
i32 4, label %sw.bb
|
||||
]
|
||||
|
||||
; CHECK: sw.bb
|
||||
sw.bb:
|
||||
%cmp = icmp sge i32 %c, 1
|
||||
; CHECK: br i1 true
|
||||
br i1 %cmp, label %if.then, label %if.end
|
||||
|
||||
if.then:
|
||||
br label %return
|
||||
|
||||
if.end:
|
||||
br label %return
|
||||
|
||||
sw.default:
|
||||
br label %return
|
||||
|
||||
return:
|
||||
%retval.0 = phi i32 [ 42, %sw.default ], [ 4, %if.then ], [ 9, %if.end ]
|
||||
ret i32 %retval.0
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user