mirror of
https://github.com/RPCS3/llvm.git
synced 2025-01-19 00:14:20 +00:00
[ConstantRange] Add an getEquivalentICmp helper
Currently only its unit test uses it, but this will be used in a later change to simplify some logic in the GuardWidening pass. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@270018 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
62dec0fa6b
commit
15c62f945a
@ -114,6 +114,11 @@ public:
|
||||
const ConstantRange &Other,
|
||||
unsigned NoWrapKind);
|
||||
|
||||
/// Set up \p Pred and \p RHS such that
|
||||
/// ConstantRange::makeExactICmpRegion(Pred, RHS) == *this. Return true if
|
||||
/// successful.
|
||||
bool getEquivalentICmp(CmpInst::Predicate &Pred, APInt &RHS) const;
|
||||
|
||||
/// Return the lower value for this range.
|
||||
///
|
||||
const APInt &getLower() const { return Lower; }
|
||||
|
@ -139,6 +139,32 @@ ConstantRange ConstantRange::makeExactICmpRegion(CmpInst::Predicate Pred,
|
||||
return makeAllowedICmpRegion(Pred, C);
|
||||
}
|
||||
|
||||
bool ConstantRange::getEquivalentICmp(CmpInst::Predicate &Pred,
|
||||
APInt &RHS) const {
|
||||
bool Success = false;
|
||||
|
||||
if (isFullSet() || isEmptySet()) {
|
||||
Pred = isEmptySet() ? CmpInst::ICMP_ULT : CmpInst::ICMP_UGE;
|
||||
RHS = APInt(getBitWidth(), 0);
|
||||
Success = true;
|
||||
} else if (getLower().isMinSignedValue() || getLower().isMinValue()) {
|
||||
Pred =
|
||||
getLower().isMinSignedValue() ? CmpInst::ICMP_SLT : CmpInst::ICMP_ULT;
|
||||
RHS = getUpper();
|
||||
Success = true;
|
||||
} else if (getUpper().isMinSignedValue() || getUpper().isMinValue()) {
|
||||
Pred =
|
||||
getUpper().isMinSignedValue() ? CmpInst::ICMP_SGE : CmpInst::ICMP_UGE;
|
||||
RHS = getLower();
|
||||
Success = true;
|
||||
}
|
||||
|
||||
assert((!Success || ConstantRange::makeExactICmpRegion(Pred, RHS) == *this) &&
|
||||
"Bad result!");
|
||||
|
||||
return Success;
|
||||
}
|
||||
|
||||
ConstantRange
|
||||
ConstantRange::makeGuaranteedNoWrapRegion(Instruction::BinaryOps BinOp,
|
||||
const ConstantRange &Other,
|
||||
|
@ -716,4 +716,50 @@ TEST(ConstantRange, MakeGuaranteedNoWrapRegion) {
|
||||
ConstantRange(APInt(32, 0), APInt(32, 1)));
|
||||
}
|
||||
|
||||
TEST(ConstantRange, GetEquivalentICmp) {
|
||||
APInt RHS;
|
||||
CmpInst::Predicate Pred;
|
||||
|
||||
EXPECT_TRUE(ConstantRange(APInt::getMinValue(32), APInt(32, 100))
|
||||
.getEquivalentICmp(Pred, RHS));
|
||||
EXPECT_EQ(Pred, CmpInst::ICMP_ULT);
|
||||
EXPECT_EQ(RHS, APInt(32, 100));
|
||||
|
||||
EXPECT_TRUE(ConstantRange(APInt::getSignedMinValue(32), APInt(32, 100))
|
||||
.getEquivalentICmp(Pred, RHS));
|
||||
EXPECT_EQ(Pred, CmpInst::ICMP_SLT);
|
||||
EXPECT_EQ(RHS, APInt(32, 100));
|
||||
|
||||
EXPECT_TRUE(ConstantRange(APInt(32, 100), APInt::getMinValue(32))
|
||||
.getEquivalentICmp(Pred, RHS));
|
||||
EXPECT_EQ(Pred, CmpInst::ICMP_UGE);
|
||||
EXPECT_EQ(RHS, APInt(32, 100));
|
||||
|
||||
EXPECT_TRUE(ConstantRange(APInt(32, 100), APInt::getSignedMinValue(32))
|
||||
.getEquivalentICmp(Pred, RHS));
|
||||
EXPECT_EQ(Pred, CmpInst::ICMP_SGE);
|
||||
EXPECT_EQ(RHS, APInt(32, 100));
|
||||
|
||||
EXPECT_TRUE(
|
||||
ConstantRange(32, /*isFullSet=*/true).getEquivalentICmp(Pred, RHS));
|
||||
EXPECT_EQ(Pred, CmpInst::ICMP_UGE);
|
||||
EXPECT_EQ(RHS, APInt(32, 0));
|
||||
|
||||
EXPECT_TRUE(
|
||||
ConstantRange(32, /*isFullSet=*/false).getEquivalentICmp(Pred, RHS));
|
||||
EXPECT_EQ(Pred, CmpInst::ICMP_ULT);
|
||||
EXPECT_EQ(RHS, APInt(32, 0));
|
||||
|
||||
EXPECT_FALSE(ConstantRange(APInt(32, 100), APInt(32, 200))
|
||||
.getEquivalentICmp(Pred, RHS));
|
||||
|
||||
EXPECT_FALSE(ConstantRange(APInt::getSignedMinValue(32) - APInt(32, 100),
|
||||
APInt::getSignedMinValue(32) + APInt(32, 100))
|
||||
.getEquivalentICmp(Pred, RHS));
|
||||
|
||||
EXPECT_FALSE(ConstantRange(APInt::getMinValue(32) - APInt(32, 100),
|
||||
APInt::getMinValue(32) + APInt(32, 100))
|
||||
.getEquivalentICmp(Pred, RHS));
|
||||
}
|
||||
|
||||
} // anonymous namespace
|
||||
|
Loading…
x
Reference in New Issue
Block a user