mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-01-31 20:51:52 +01:00
Make ConstantRange::makeICmpRegion handle all the edge cases properly. This
also fixes PR8250. llvm-svn: 114972
This commit is contained in:
parent
e1f502ee26
commit
69d1069a4b
@ -51,6 +51,9 @@ ConstantRange::ConstantRange(const APInt &L, const APInt &U) :
|
|||||||
|
|
||||||
ConstantRange ConstantRange::makeICmpRegion(unsigned Pred,
|
ConstantRange ConstantRange::makeICmpRegion(unsigned Pred,
|
||||||
const ConstantRange &CR) {
|
const ConstantRange &CR) {
|
||||||
|
if (CR.isEmptySet())
|
||||||
|
return CR;
|
||||||
|
|
||||||
uint32_t W = CR.getBitWidth();
|
uint32_t W = CR.getBitWidth();
|
||||||
switch (Pred) {
|
switch (Pred) {
|
||||||
default: assert(!"Invalid ICmp predicate to makeICmpRegion()");
|
default: assert(!"Invalid ICmp predicate to makeICmpRegion()");
|
||||||
@ -60,10 +63,18 @@ ConstantRange ConstantRange::makeICmpRegion(unsigned Pred,
|
|||||||
if (CR.isSingleElement())
|
if (CR.isSingleElement())
|
||||||
return ConstantRange(CR.getUpper(), CR.getLower());
|
return ConstantRange(CR.getUpper(), CR.getLower());
|
||||||
return ConstantRange(W);
|
return ConstantRange(W);
|
||||||
case ICmpInst::ICMP_ULT:
|
case ICmpInst::ICMP_ULT: {
|
||||||
return ConstantRange(APInt::getMinValue(W), CR.getUnsignedMax());
|
APInt UMax(CR.getUnsignedMax());
|
||||||
case ICmpInst::ICMP_SLT:
|
if (UMax.isMinValue())
|
||||||
return ConstantRange(APInt::getSignedMinValue(W), CR.getSignedMax());
|
return ConstantRange(W, /* empty */ false);
|
||||||
|
return ConstantRange(APInt::getMinValue(W), UMax);
|
||||||
|
}
|
||||||
|
case ICmpInst::ICMP_SLT: {
|
||||||
|
APInt SMax(CR.getSignedMax());
|
||||||
|
if (SMax.isMinSignedValue())
|
||||||
|
return ConstantRange(W, /* empty */ false);
|
||||||
|
return ConstantRange(APInt::getSignedMinValue(W), SMax);
|
||||||
|
}
|
||||||
case ICmpInst::ICMP_ULE: {
|
case ICmpInst::ICMP_ULE: {
|
||||||
APInt UMax(CR.getUnsignedMax());
|
APInt UMax(CR.getUnsignedMax());
|
||||||
if (UMax.isMaxValue())
|
if (UMax.isMaxValue())
|
||||||
@ -72,15 +83,22 @@ ConstantRange ConstantRange::makeICmpRegion(unsigned Pred,
|
|||||||
}
|
}
|
||||||
case ICmpInst::ICMP_SLE: {
|
case ICmpInst::ICMP_SLE: {
|
||||||
APInt SMax(CR.getSignedMax());
|
APInt SMax(CR.getSignedMax());
|
||||||
if (SMax.isMaxSignedValue() || (SMax+1).isMaxSignedValue())
|
if (SMax.isMaxSignedValue())
|
||||||
return ConstantRange(W);
|
return ConstantRange(W);
|
||||||
return ConstantRange(APInt::getSignedMinValue(W), SMax + 1);
|
return ConstantRange(APInt::getSignedMinValue(W), SMax + 1);
|
||||||
}
|
}
|
||||||
case ICmpInst::ICMP_UGT:
|
case ICmpInst::ICMP_UGT: {
|
||||||
return ConstantRange(CR.getUnsignedMin() + 1, APInt::getNullValue(W));
|
APInt UMin(CR.getUnsignedMin());
|
||||||
case ICmpInst::ICMP_SGT:
|
if (UMin.isMaxValue())
|
||||||
return ConstantRange(CR.getSignedMin() + 1,
|
return ConstantRange(W, /* empty */ false);
|
||||||
APInt::getSignedMinValue(W));
|
return ConstantRange(UMin + 1, APInt::getNullValue(W));
|
||||||
|
}
|
||||||
|
case ICmpInst::ICMP_SGT: {
|
||||||
|
APInt SMin(CR.getSignedMin());
|
||||||
|
if (SMin.isMaxSignedValue())
|
||||||
|
return ConstantRange(W, /* empty */ false);
|
||||||
|
return ConstantRange(SMin + 1, APInt::getSignedMinValue(W));
|
||||||
|
}
|
||||||
case ICmpInst::ICMP_UGE: {
|
case ICmpInst::ICMP_UGE: {
|
||||||
APInt UMin(CR.getUnsignedMin());
|
APInt UMin(CR.getUnsignedMin());
|
||||||
if (UMin.isMinValue())
|
if (UMin.isMinValue())
|
||||||
|
@ -8,6 +8,7 @@
|
|||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
#include "llvm/Support/ConstantRange.h"
|
#include "llvm/Support/ConstantRange.h"
|
||||||
|
#include "llvm/Instructions.h"
|
||||||
|
|
||||||
#include "gtest/gtest.h"
|
#include "gtest/gtest.h"
|
||||||
|
|
||||||
@ -429,4 +430,11 @@ TEST_F(ConstantRangeTest, Lshr) {
|
|||||||
EXPECT_EQ(Wrap.lshr(Wrap), Full);
|
EXPECT_EQ(Wrap.lshr(Wrap), Full);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
TEST(ConstantRange, MakeICmpRegion) {
|
||||||
|
// PR8250
|
||||||
|
ConstantRange SMax = ConstantRange(APInt::getSignedMaxValue(32));
|
||||||
|
EXPECT_TRUE(ConstantRange::makeICmpRegion(ICmpInst::ICMP_SGT,
|
||||||
|
SMax).isEmptySet());
|
||||||
|
}
|
||||||
|
|
||||||
} // anonymous namespace
|
} // anonymous namespace
|
||||||
|
Loading…
x
Reference in New Issue
Block a user