1 //===- ConstantRange.cpp - ConstantRange implementation -------------------===//
2 //
3 //                     The LLVM Compiler Infrastructure
4 //
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
7 //
8 //===----------------------------------------------------------------------===//
9 //
10 // Represent a range of possible values that may occur when the program is run
11 // for an integral value.  This keeps track of a lower and upper bound for the
12 // constant, which MAY wrap around the end of the numeric range.  To do this, it
13 // keeps track of a [lower, upper) bound, which specifies an interval just like
14 // STL iterators.  When used with boolean values, the following are important
15 // ranges (other integral ranges use min/max values for special range values):
16 //
17 //  [F, F) = {}     = Empty set
18 //  [T, F) = {T}
19 //  [F, T) = {F}
20 //  [T, T) = {F, T} = Full set
21 //
22 //===----------------------------------------------------------------------===//
23 
24 #include "llvm/ADT/APInt.h"
25 #include "llvm/Config/llvm-config.h"
26 #include "llvm/IR/ConstantRange.h"
27 #include "llvm/IR/Constants.h"
28 #include "llvm/IR/InstrTypes.h"
29 #include "llvm/IR/Instruction.h"
30 #include "llvm/IR/Metadata.h"
31 #include "llvm/IR/Operator.h"
32 #include "llvm/Support/Compiler.h"
33 #include "llvm/Support/Debug.h"
34 #include "llvm/Support/ErrorHandling.h"
35 #include "llvm/Support/raw_ostream.h"
36 #include <algorithm>
37 #include <cassert>
38 #include <cstdint>
39 
40 using namespace llvm;
41 
ConstantRange(uint32_t BitWidth,bool Full)42 ConstantRange::ConstantRange(uint32_t BitWidth, bool Full)
43     : Lower(Full ? APInt::getMaxValue(BitWidth) : APInt::getMinValue(BitWidth)),
44       Upper(Lower) {}
45 
ConstantRange(APInt V)46 ConstantRange::ConstantRange(APInt V)
47     : Lower(std::move(V)), Upper(Lower + 1) {}
48 
ConstantRange(APInt L,APInt U)49 ConstantRange::ConstantRange(APInt L, APInt U)
50     : Lower(std::move(L)), Upper(std::move(U)) {
51   assert(Lower.getBitWidth() == Upper.getBitWidth() &&
52          "ConstantRange with unequal bit widths");
53   assert((Lower != Upper || (Lower.isMaxValue() || Lower.isMinValue())) &&
54          "Lower == Upper, but they aren't min or max value!");
55 }
56 
makeAllowedICmpRegion(CmpInst::Predicate Pred,const ConstantRange & CR)57 ConstantRange ConstantRange::makeAllowedICmpRegion(CmpInst::Predicate Pred,
58                                                    const ConstantRange &CR) {
59   if (CR.isEmptySet())
60     return CR;
61 
62   uint32_t W = CR.getBitWidth();
63   switch (Pred) {
64   default:
65     llvm_unreachable("Invalid ICmp predicate to makeAllowedICmpRegion()");
66   case CmpInst::ICMP_EQ:
67     return CR;
68   case CmpInst::ICMP_NE:
69     if (CR.isSingleElement())
70       return ConstantRange(CR.getUpper(), CR.getLower());
71     return ConstantRange(W);
72   case CmpInst::ICMP_ULT: {
73     APInt UMax(CR.getUnsignedMax());
74     if (UMax.isMinValue())
75       return ConstantRange(W, /* empty */ false);
76     return ConstantRange(APInt::getMinValue(W), std::move(UMax));
77   }
78   case CmpInst::ICMP_SLT: {
79     APInt SMax(CR.getSignedMax());
80     if (SMax.isMinSignedValue())
81       return ConstantRange(W, /* empty */ false);
82     return ConstantRange(APInt::getSignedMinValue(W), std::move(SMax));
83   }
84   case CmpInst::ICMP_ULE: {
85     APInt UMax(CR.getUnsignedMax());
86     if (UMax.isMaxValue())
87       return ConstantRange(W);
88     return ConstantRange(APInt::getMinValue(W), std::move(UMax) + 1);
89   }
90   case CmpInst::ICMP_SLE: {
91     APInt SMax(CR.getSignedMax());
92     if (SMax.isMaxSignedValue())
93       return ConstantRange(W);
94     return ConstantRange(APInt::getSignedMinValue(W), std::move(SMax) + 1);
95   }
96   case CmpInst::ICMP_UGT: {
97     APInt UMin(CR.getUnsignedMin());
98     if (UMin.isMaxValue())
99       return ConstantRange(W, /* empty */ false);
100     return ConstantRange(std::move(UMin) + 1, APInt::getNullValue(W));
101   }
102   case CmpInst::ICMP_SGT: {
103     APInt SMin(CR.getSignedMin());
104     if (SMin.isMaxSignedValue())
105       return ConstantRange(W, /* empty */ false);
106     return ConstantRange(std::move(SMin) + 1, APInt::getSignedMinValue(W));
107   }
108   case CmpInst::ICMP_UGE: {
109     APInt UMin(CR.getUnsignedMin());
110     if (UMin.isMinValue())
111       return ConstantRange(W);
112     return ConstantRange(std::move(UMin), APInt::getNullValue(W));
113   }
114   case CmpInst::ICMP_SGE: {
115     APInt SMin(CR.getSignedMin());
116     if (SMin.isMinSignedValue())
117       return ConstantRange(W);
118     return ConstantRange(std::move(SMin), APInt::getSignedMinValue(W));
119   }
120   }
121 }
122 
makeSatisfyingICmpRegion(CmpInst::Predicate Pred,const ConstantRange & CR)123 ConstantRange ConstantRange::makeSatisfyingICmpRegion(CmpInst::Predicate Pred,
124                                                       const ConstantRange &CR) {
125   // Follows from De-Morgan's laws:
126   //
127   // ~(~A union ~B) == A intersect B.
128   //
129   return makeAllowedICmpRegion(CmpInst::getInversePredicate(Pred), CR)
130       .inverse();
131 }
132 
makeExactICmpRegion(CmpInst::Predicate Pred,const APInt & C)133 ConstantRange ConstantRange::makeExactICmpRegion(CmpInst::Predicate Pred,
134                                                  const APInt &C) {
135   // Computes the exact range that is equal to both the constant ranges returned
136   // by makeAllowedICmpRegion and makeSatisfyingICmpRegion. This is always true
137   // when RHS is a singleton such as an APInt and so the assert is valid.
138   // However for non-singleton RHS, for example ult [2,5) makeAllowedICmpRegion
139   // returns [0,4) but makeSatisfyICmpRegion returns [0,2).
140   //
141   assert(makeAllowedICmpRegion(Pred, C) == makeSatisfyingICmpRegion(Pred, C));
142   return makeAllowedICmpRegion(Pred, C);
143 }
144 
getEquivalentICmp(CmpInst::Predicate & Pred,APInt & RHS) const145 bool ConstantRange::getEquivalentICmp(CmpInst::Predicate &Pred,
146                                       APInt &RHS) const {
147   bool Success = false;
148 
149   if (isFullSet() || isEmptySet()) {
150     Pred = isEmptySet() ? CmpInst::ICMP_ULT : CmpInst::ICMP_UGE;
151     RHS = APInt(getBitWidth(), 0);
152     Success = true;
153   } else if (auto *OnlyElt = getSingleElement()) {
154     Pred = CmpInst::ICMP_EQ;
155     RHS = *OnlyElt;
156     Success = true;
157   } else if (auto *OnlyMissingElt = getSingleMissingElement()) {
158     Pred = CmpInst::ICMP_NE;
159     RHS = *OnlyMissingElt;
160     Success = true;
161   } else if (getLower().isMinSignedValue() || getLower().isMinValue()) {
162     Pred =
163         getLower().isMinSignedValue() ? CmpInst::ICMP_SLT : CmpInst::ICMP_ULT;
164     RHS = getUpper();
165     Success = true;
166   } else if (getUpper().isMinSignedValue() || getUpper().isMinValue()) {
167     Pred =
168         getUpper().isMinSignedValue() ? CmpInst::ICMP_SGE : CmpInst::ICMP_UGE;
169     RHS = getLower();
170     Success = true;
171   }
172 
173   assert((!Success || ConstantRange::makeExactICmpRegion(Pred, RHS) == *this) &&
174          "Bad result!");
175 
176   return Success;
177 }
178 
179 ConstantRange
makeGuaranteedNoWrapRegion(Instruction::BinaryOps BinOp,const ConstantRange & Other,unsigned NoWrapKind)180 ConstantRange::makeGuaranteedNoWrapRegion(Instruction::BinaryOps BinOp,
181                                           const ConstantRange &Other,
182                                           unsigned NoWrapKind) {
183   using OBO = OverflowingBinaryOperator;
184 
185   // Computes the intersection of CR0 and CR1.  It is different from
186   // intersectWith in that the ConstantRange returned will only contain elements
187   // in both CR0 and CR1 (i.e. SubsetIntersect(X, Y) is a *subset*, proper or
188   // not, of both X and Y).
189   auto SubsetIntersect =
190       [](const ConstantRange &CR0, const ConstantRange &CR1) {
191     return CR0.inverse().unionWith(CR1.inverse()).inverse();
192   };
193 
194   assert(Instruction::isBinaryOp(BinOp) && "Binary operators only!");
195 
196   assert((NoWrapKind == OBO::NoSignedWrap ||
197           NoWrapKind == OBO::NoUnsignedWrap ||
198           NoWrapKind == (OBO::NoUnsignedWrap | OBO::NoSignedWrap)) &&
199          "NoWrapKind invalid!");
200 
201   unsigned BitWidth = Other.getBitWidth();
202   ConstantRange Result(BitWidth);
203 
204   switch (BinOp) {
205   default:
206     // Conservative answer: empty set
207     return ConstantRange(BitWidth, false);
208 
209   case Instruction::Add:
210     if (auto *C = Other.getSingleElement())
211       if (C->isNullValue())
212         // Full set: nothing signed / unsigned wraps when added to 0.
213         return ConstantRange(BitWidth);
214     if (NoWrapKind & OBO::NoUnsignedWrap)
215       Result =
216           SubsetIntersect(Result, ConstantRange(APInt::getNullValue(BitWidth),
217                                                 -Other.getUnsignedMax()));
218     if (NoWrapKind & OBO::NoSignedWrap) {
219       const APInt &SignedMin = Other.getSignedMin();
220       const APInt &SignedMax = Other.getSignedMax();
221       if (SignedMax.isStrictlyPositive())
222         Result = SubsetIntersect(
223             Result,
224             ConstantRange(APInt::getSignedMinValue(BitWidth),
225                           APInt::getSignedMinValue(BitWidth) - SignedMax));
226       if (SignedMin.isNegative())
227         Result = SubsetIntersect(
228             Result,
229             ConstantRange(APInt::getSignedMinValue(BitWidth) - SignedMin,
230                           APInt::getSignedMinValue(BitWidth)));
231     }
232     return Result;
233 
234   case Instruction::Sub:
235     if (auto *C = Other.getSingleElement())
236       if (C->isNullValue())
237         // Full set: nothing signed / unsigned wraps when subtracting 0.
238         return ConstantRange(BitWidth);
239     if (NoWrapKind & OBO::NoUnsignedWrap)
240       Result =
241           SubsetIntersect(Result, ConstantRange(Other.getUnsignedMax(),
242                                                 APInt::getMinValue(BitWidth)));
243     if (NoWrapKind & OBO::NoSignedWrap) {
244       const APInt &SignedMin = Other.getSignedMin();
245       const APInt &SignedMax = Other.getSignedMax();
246       if (SignedMax.isStrictlyPositive())
247         Result = SubsetIntersect(
248             Result,
249             ConstantRange(APInt::getSignedMinValue(BitWidth) + SignedMax,
250                           APInt::getSignedMinValue(BitWidth)));
251       if (SignedMin.isNegative())
252         Result = SubsetIntersect(
253             Result,
254             ConstantRange(APInt::getSignedMinValue(BitWidth),
255                           APInt::getSignedMinValue(BitWidth) + SignedMin));
256     }
257     return Result;
258   case Instruction::Mul: {
259     if (NoWrapKind == (OBO::NoSignedWrap | OBO::NoUnsignedWrap)) {
260       return SubsetIntersect(
261           makeGuaranteedNoWrapRegion(BinOp, Other, OBO::NoSignedWrap),
262           makeGuaranteedNoWrapRegion(BinOp, Other, OBO::NoUnsignedWrap));
263     }
264 
265     // Equivalent to calling makeGuaranteedNoWrapRegion() on [V, V+1).
266     const bool Unsigned = NoWrapKind == OBO::NoUnsignedWrap;
267     const auto makeSingleValueRegion = [Unsigned,
268                                         BitWidth](APInt V) -> ConstantRange {
269       // Handle special case for 0, -1 and 1. See the last for reason why we
270       // specialize -1 and 1.
271       if (V == 0 || V.isOneValue())
272         return ConstantRange(BitWidth, true);
273 
274       APInt MinValue, MaxValue;
275       if (Unsigned) {
276         MinValue = APInt::getMinValue(BitWidth);
277         MaxValue = APInt::getMaxValue(BitWidth);
278       } else {
279         MinValue = APInt::getSignedMinValue(BitWidth);
280         MaxValue = APInt::getSignedMaxValue(BitWidth);
281       }
282       // e.g. Returning [-127, 127], represented as [-127, -128).
283       if (!Unsigned && V.isAllOnesValue())
284         return ConstantRange(-MaxValue, MinValue);
285 
286       APInt Lower, Upper;
287       if (!Unsigned && V.isNegative()) {
288         Lower = APIntOps::RoundingSDiv(MaxValue, V, APInt::Rounding::UP);
289         Upper = APIntOps::RoundingSDiv(MinValue, V, APInt::Rounding::DOWN);
290       } else if (Unsigned) {
291         Lower = APIntOps::RoundingUDiv(MinValue, V, APInt::Rounding::UP);
292         Upper = APIntOps::RoundingUDiv(MaxValue, V, APInt::Rounding::DOWN);
293       } else {
294         Lower = APIntOps::RoundingSDiv(MinValue, V, APInt::Rounding::UP);
295         Upper = APIntOps::RoundingSDiv(MaxValue, V, APInt::Rounding::DOWN);
296       }
297       if (Unsigned) {
298         Lower = Lower.zextOrSelf(BitWidth);
299         Upper = Upper.zextOrSelf(BitWidth);
300       } else {
301         Lower = Lower.sextOrSelf(BitWidth);
302         Upper = Upper.sextOrSelf(BitWidth);
303       }
304       // ConstantRange ctor take a half inclusive interval [Lower, Upper + 1).
305       // Upper + 1 is guanranteed not to overflow, because |divisor| > 1. 0, -1,
306       // and 1 are already handled as special cases.
307       return ConstantRange(Lower, Upper + 1);
308     };
309 
310     if (Unsigned)
311       return makeSingleValueRegion(Other.getUnsignedMax());
312 
313     return SubsetIntersect(makeSingleValueRegion(Other.getSignedMin()),
314                            makeSingleValueRegion(Other.getSignedMax()));
315   }
316   }
317 }
318 
isFullSet() const319 bool ConstantRange::isFullSet() const {
320   return Lower == Upper && Lower.isMaxValue();
321 }
322 
isEmptySet() const323 bool ConstantRange::isEmptySet() const {
324   return Lower == Upper && Lower.isMinValue();
325 }
326 
isWrappedSet() const327 bool ConstantRange::isWrappedSet() const {
328   return Lower.ugt(Upper);
329 }
330 
isSignWrappedSet() const331 bool ConstantRange::isSignWrappedSet() const {
332   return contains(APInt::getSignedMaxValue(getBitWidth())) &&
333          contains(APInt::getSignedMinValue(getBitWidth()));
334 }
335 
getSetSize() const336 APInt ConstantRange::getSetSize() const {
337   if (isFullSet())
338     return APInt::getOneBitSet(getBitWidth()+1, getBitWidth());
339 
340   // This is also correct for wrapped sets.
341   return (Upper - Lower).zext(getBitWidth()+1);
342 }
343 
344 bool
isSizeStrictlySmallerThan(const ConstantRange & Other) const345 ConstantRange::isSizeStrictlySmallerThan(const ConstantRange &Other) const {
346   assert(getBitWidth() == Other.getBitWidth());
347   if (isFullSet())
348     return false;
349   if (Other.isFullSet())
350     return true;
351   return (Upper - Lower).ult(Other.Upper - Other.Lower);
352 }
353 
354 bool
isSizeLargerThan(uint64_t MaxSize) const355 ConstantRange::isSizeLargerThan(uint64_t MaxSize) const {
356   assert(MaxSize && "MaxSize can't be 0.");
357   // If this a full set, we need special handling to avoid needing an extra bit
358   // to represent the size.
359   if (isFullSet())
360     return APInt::getMaxValue(getBitWidth()).ugt(MaxSize - 1);
361 
362   return (Upper - Lower).ugt(MaxSize);
363 }
364 
getUnsignedMax() const365 APInt ConstantRange::getUnsignedMax() const {
366   if (isFullSet() || isWrappedSet())
367     return APInt::getMaxValue(getBitWidth());
368   return getUpper() - 1;
369 }
370 
getUnsignedMin() const371 APInt ConstantRange::getUnsignedMin() const {
372   if (isFullSet() || (isWrappedSet() && !getUpper().isNullValue()))
373     return APInt::getMinValue(getBitWidth());
374   return getLower();
375 }
376 
getSignedMax() const377 APInt ConstantRange::getSignedMax() const {
378   if (isFullSet() || Lower.sgt(Upper))
379     return APInt::getSignedMaxValue(getBitWidth());
380   return getUpper() - 1;
381 }
382 
getSignedMin() const383 APInt ConstantRange::getSignedMin() const {
384   if (isFullSet() || (Lower.sgt(Upper) && !getUpper().isMinSignedValue()))
385     return APInt::getSignedMinValue(getBitWidth());
386   return getLower();
387 }
388 
contains(const APInt & V) const389 bool ConstantRange::contains(const APInt &V) const {
390   if (Lower == Upper)
391     return isFullSet();
392 
393   if (!isWrappedSet())
394     return Lower.ule(V) && V.ult(Upper);
395   return Lower.ule(V) || V.ult(Upper);
396 }
397 
contains(const ConstantRange & Other) const398 bool ConstantRange::contains(const ConstantRange &Other) const {
399   if (isFullSet() || Other.isEmptySet()) return true;
400   if (isEmptySet() || Other.isFullSet()) return false;
401 
402   if (!isWrappedSet()) {
403     if (Other.isWrappedSet())
404       return false;
405 
406     return Lower.ule(Other.getLower()) && Other.getUpper().ule(Upper);
407   }
408 
409   if (!Other.isWrappedSet())
410     return Other.getUpper().ule(Upper) ||
411            Lower.ule(Other.getLower());
412 
413   return Other.getUpper().ule(Upper) && Lower.ule(Other.getLower());
414 }
415 
subtract(const APInt & Val) const416 ConstantRange ConstantRange::subtract(const APInt &Val) const {
417   assert(Val.getBitWidth() == getBitWidth() && "Wrong bit width");
418   // If the set is empty or full, don't modify the endpoints.
419   if (Lower == Upper)
420     return *this;
421   return ConstantRange(Lower - Val, Upper - Val);
422 }
423 
difference(const ConstantRange & CR) const424 ConstantRange ConstantRange::difference(const ConstantRange &CR) const {
425   return intersectWith(CR.inverse());
426 }
427 
intersectWith(const ConstantRange & CR) const428 ConstantRange ConstantRange::intersectWith(const ConstantRange &CR) const {
429   assert(getBitWidth() == CR.getBitWidth() &&
430          "ConstantRange types don't agree!");
431 
432   // Handle common cases.
433   if (   isEmptySet() || CR.isFullSet()) return *this;
434   if (CR.isEmptySet() ||    isFullSet()) return CR;
435 
436   if (!isWrappedSet() && CR.isWrappedSet())
437     return CR.intersectWith(*this);
438 
439   if (!isWrappedSet() && !CR.isWrappedSet()) {
440     if (Lower.ult(CR.Lower)) {
441       if (Upper.ule(CR.Lower))
442         return ConstantRange(getBitWidth(), false);
443 
444       if (Upper.ult(CR.Upper))
445         return ConstantRange(CR.Lower, Upper);
446 
447       return CR;
448     }
449     if (Upper.ult(CR.Upper))
450       return *this;
451 
452     if (Lower.ult(CR.Upper))
453       return ConstantRange(Lower, CR.Upper);
454 
455     return ConstantRange(getBitWidth(), false);
456   }
457 
458   if (isWrappedSet() && !CR.isWrappedSet()) {
459     if (CR.Lower.ult(Upper)) {
460       if (CR.Upper.ult(Upper))
461         return CR;
462 
463       if (CR.Upper.ule(Lower))
464         return ConstantRange(CR.Lower, Upper);
465 
466       if (isSizeStrictlySmallerThan(CR))
467         return *this;
468       return CR;
469     }
470     if (CR.Lower.ult(Lower)) {
471       if (CR.Upper.ule(Lower))
472         return ConstantRange(getBitWidth(), false);
473 
474       return ConstantRange(Lower, CR.Upper);
475     }
476     return CR;
477   }
478 
479   if (CR.Upper.ult(Upper)) {
480     if (CR.Lower.ult(Upper)) {
481       if (isSizeStrictlySmallerThan(CR))
482         return *this;
483       return CR;
484     }
485 
486     if (CR.Lower.ult(Lower))
487       return ConstantRange(Lower, CR.Upper);
488 
489     return CR;
490   }
491   if (CR.Upper.ule(Lower)) {
492     if (CR.Lower.ult(Lower))
493       return *this;
494 
495     return ConstantRange(CR.Lower, Upper);
496   }
497   if (isSizeStrictlySmallerThan(CR))
498     return *this;
499   return CR;
500 }
501 
unionWith(const ConstantRange & CR) const502 ConstantRange ConstantRange::unionWith(const ConstantRange &CR) const {
503   assert(getBitWidth() == CR.getBitWidth() &&
504          "ConstantRange types don't agree!");
505 
506   if (   isFullSet() || CR.isEmptySet()) return *this;
507   if (CR.isFullSet() ||    isEmptySet()) return CR;
508 
509   if (!isWrappedSet() && CR.isWrappedSet()) return CR.unionWith(*this);
510 
511   if (!isWrappedSet() && !CR.isWrappedSet()) {
512     if (CR.Upper.ult(Lower) || Upper.ult(CR.Lower)) {
513       // If the two ranges are disjoint, find the smaller gap and bridge it.
514       APInt d1 = CR.Lower - Upper, d2 = Lower - CR.Upper;
515       if (d1.ult(d2))
516         return ConstantRange(Lower, CR.Upper);
517       return ConstantRange(CR.Lower, Upper);
518     }
519 
520     APInt L = CR.Lower.ult(Lower) ? CR.Lower : Lower;
521     APInt U = (CR.Upper - 1).ugt(Upper - 1) ? CR.Upper : Upper;
522 
523     if (L.isNullValue() && U.isNullValue())
524       return ConstantRange(getBitWidth());
525 
526     return ConstantRange(std::move(L), std::move(U));
527   }
528 
529   if (!CR.isWrappedSet()) {
530     // ------U   L-----  and  ------U   L----- : this
531     //   L--U                            L--U  : CR
532     if (CR.Upper.ule(Upper) || CR.Lower.uge(Lower))
533       return *this;
534 
535     // ------U   L----- : this
536     //    L---------U   : CR
537     if (CR.Lower.ule(Upper) && Lower.ule(CR.Upper))
538       return ConstantRange(getBitWidth());
539 
540     // ----U       L---- : this
541     //       L---U       : CR
542     //    <d1>  <d2>
543     if (Upper.ule(CR.Lower) && CR.Upper.ule(Lower)) {
544       APInt d1 = CR.Lower - Upper, d2 = Lower - CR.Upper;
545       if (d1.ult(d2))
546         return ConstantRange(Lower, CR.Upper);
547       return ConstantRange(CR.Lower, Upper);
548     }
549 
550     // ----U     L----- : this
551     //        L----U    : CR
552     if (Upper.ult(CR.Lower) && Lower.ult(CR.Upper))
553       return ConstantRange(CR.Lower, Upper);
554 
555     // ------U    L---- : this
556     //    L-----U       : CR
557     assert(CR.Lower.ult(Upper) && CR.Upper.ult(Lower) &&
558            "ConstantRange::unionWith missed a case with one range wrapped");
559     return ConstantRange(Lower, CR.Upper);
560   }
561 
562   // ------U    L----  and  ------U    L---- : this
563   // -U  L-----------  and  ------------U  L : CR
564   if (CR.Lower.ule(Upper) || Lower.ule(CR.Upper))
565     return ConstantRange(getBitWidth());
566 
567   APInt L = CR.Lower.ult(Lower) ? CR.Lower : Lower;
568   APInt U = CR.Upper.ugt(Upper) ? CR.Upper : Upper;
569 
570   return ConstantRange(std::move(L), std::move(U));
571 }
572 
castOp(Instruction::CastOps CastOp,uint32_t ResultBitWidth) const573 ConstantRange ConstantRange::castOp(Instruction::CastOps CastOp,
574                                     uint32_t ResultBitWidth) const {
575   switch (CastOp) {
576   default:
577     llvm_unreachable("unsupported cast type");
578   case Instruction::Trunc:
579     return truncate(ResultBitWidth);
580   case Instruction::SExt:
581     return signExtend(ResultBitWidth);
582   case Instruction::ZExt:
583     return zeroExtend(ResultBitWidth);
584   case Instruction::BitCast:
585     return *this;
586   case Instruction::FPToUI:
587   case Instruction::FPToSI:
588     if (getBitWidth() == ResultBitWidth)
589       return *this;
590     else
591       return ConstantRange(getBitWidth(), /*isFullSet=*/true);
592   case Instruction::UIToFP: {
593     // TODO: use input range if available
594     auto BW = getBitWidth();
595     APInt Min = APInt::getMinValue(BW).zextOrSelf(ResultBitWidth);
596     APInt Max = APInt::getMaxValue(BW).zextOrSelf(ResultBitWidth);
597     return ConstantRange(std::move(Min), std::move(Max));
598   }
599   case Instruction::SIToFP: {
600     // TODO: use input range if available
601     auto BW = getBitWidth();
602     APInt SMin = APInt::getSignedMinValue(BW).sextOrSelf(ResultBitWidth);
603     APInt SMax = APInt::getSignedMaxValue(BW).sextOrSelf(ResultBitWidth);
604     return ConstantRange(std::move(SMin), std::move(SMax));
605   }
606   case Instruction::FPTrunc:
607   case Instruction::FPExt:
608   case Instruction::IntToPtr:
609   case Instruction::PtrToInt:
610   case Instruction::AddrSpaceCast:
611     // Conservatively return full set.
612     return ConstantRange(getBitWidth(), /*isFullSet=*/true);
613   };
614 }
615 
zeroExtend(uint32_t DstTySize) const616 ConstantRange ConstantRange::zeroExtend(uint32_t DstTySize) const {
617   if (isEmptySet()) return ConstantRange(DstTySize, /*isFullSet=*/false);
618 
619   unsigned SrcTySize = getBitWidth();
620   assert(SrcTySize < DstTySize && "Not a value extension");
621   if (isFullSet() || isWrappedSet()) {
622     // Change into [0, 1 << src bit width)
623     APInt LowerExt(DstTySize, 0);
624     if (!Upper) // special case: [X, 0) -- not really wrapping around
625       LowerExt = Lower.zext(DstTySize);
626     return ConstantRange(std::move(LowerExt),
627                          APInt::getOneBitSet(DstTySize, SrcTySize));
628   }
629 
630   return ConstantRange(Lower.zext(DstTySize), Upper.zext(DstTySize));
631 }
632 
signExtend(uint32_t DstTySize) const633 ConstantRange ConstantRange::signExtend(uint32_t DstTySize) const {
634   if (isEmptySet()) return ConstantRange(DstTySize, /*isFullSet=*/false);
635 
636   unsigned SrcTySize = getBitWidth();
637   assert(SrcTySize < DstTySize && "Not a value extension");
638 
639   // special case: [X, INT_MIN) -- not really wrapping around
640   if (Upper.isMinSignedValue())
641     return ConstantRange(Lower.sext(DstTySize), Upper.zext(DstTySize));
642 
643   if (isFullSet() || isSignWrappedSet()) {
644     return ConstantRange(APInt::getHighBitsSet(DstTySize,DstTySize-SrcTySize+1),
645                          APInt::getLowBitsSet(DstTySize, SrcTySize-1) + 1);
646   }
647 
648   return ConstantRange(Lower.sext(DstTySize), Upper.sext(DstTySize));
649 }
650 
truncate(uint32_t DstTySize) const651 ConstantRange ConstantRange::truncate(uint32_t DstTySize) const {
652   assert(getBitWidth() > DstTySize && "Not a value truncation");
653   if (isEmptySet())
654     return ConstantRange(DstTySize, /*isFullSet=*/false);
655   if (isFullSet())
656     return ConstantRange(DstTySize, /*isFullSet=*/true);
657 
658   APInt LowerDiv(Lower), UpperDiv(Upper);
659   ConstantRange Union(DstTySize, /*isFullSet=*/false);
660 
661   // Analyze wrapped sets in their two parts: [0, Upper) \/ [Lower, MaxValue]
662   // We use the non-wrapped set code to analyze the [Lower, MaxValue) part, and
663   // then we do the union with [MaxValue, Upper)
664   if (isWrappedSet()) {
665     // If Upper is greater than or equal to MaxValue(DstTy), it covers the whole
666     // truncated range.
667     if (Upper.getActiveBits() > DstTySize ||
668         Upper.countTrailingOnes() == DstTySize)
669       return ConstantRange(DstTySize, /*isFullSet=*/true);
670 
671     Union = ConstantRange(APInt::getMaxValue(DstTySize),Upper.trunc(DstTySize));
672     UpperDiv.setAllBits();
673 
674     // Union covers the MaxValue case, so return if the remaining range is just
675     // MaxValue(DstTy).
676     if (LowerDiv == UpperDiv)
677       return Union;
678   }
679 
680   // Chop off the most significant bits that are past the destination bitwidth.
681   if (LowerDiv.getActiveBits() > DstTySize) {
682     // Mask to just the signficant bits and subtract from LowerDiv/UpperDiv.
683     APInt Adjust = LowerDiv & APInt::getBitsSetFrom(getBitWidth(), DstTySize);
684     LowerDiv -= Adjust;
685     UpperDiv -= Adjust;
686   }
687 
688   unsigned UpperDivWidth = UpperDiv.getActiveBits();
689   if (UpperDivWidth <= DstTySize)
690     return ConstantRange(LowerDiv.trunc(DstTySize),
691                          UpperDiv.trunc(DstTySize)).unionWith(Union);
692 
693   // The truncated value wraps around. Check if we can do better than fullset.
694   if (UpperDivWidth == DstTySize + 1) {
695     // Clear the MSB so that UpperDiv wraps around.
696     UpperDiv.clearBit(DstTySize);
697     if (UpperDiv.ult(LowerDiv))
698       return ConstantRange(LowerDiv.trunc(DstTySize),
699                            UpperDiv.trunc(DstTySize)).unionWith(Union);
700   }
701 
702   return ConstantRange(DstTySize, /*isFullSet=*/true);
703 }
704 
zextOrTrunc(uint32_t DstTySize) const705 ConstantRange ConstantRange::zextOrTrunc(uint32_t DstTySize) const {
706   unsigned SrcTySize = getBitWidth();
707   if (SrcTySize > DstTySize)
708     return truncate(DstTySize);
709   if (SrcTySize < DstTySize)
710     return zeroExtend(DstTySize);
711   return *this;
712 }
713 
sextOrTrunc(uint32_t DstTySize) const714 ConstantRange ConstantRange::sextOrTrunc(uint32_t DstTySize) const {
715   unsigned SrcTySize = getBitWidth();
716   if (SrcTySize > DstTySize)
717     return truncate(DstTySize);
718   if (SrcTySize < DstTySize)
719     return signExtend(DstTySize);
720   return *this;
721 }
722 
binaryOp(Instruction::BinaryOps BinOp,const ConstantRange & Other) const723 ConstantRange ConstantRange::binaryOp(Instruction::BinaryOps BinOp,
724                                       const ConstantRange &Other) const {
725   assert(Instruction::isBinaryOp(BinOp) && "Binary operators only!");
726 
727   switch (BinOp) {
728   case Instruction::Add:
729     return add(Other);
730   case Instruction::Sub:
731     return sub(Other);
732   case Instruction::Mul:
733     return multiply(Other);
734   case Instruction::UDiv:
735     return udiv(Other);
736   case Instruction::Shl:
737     return shl(Other);
738   case Instruction::LShr:
739     return lshr(Other);
740   case Instruction::AShr:
741     return ashr(Other);
742   case Instruction::And:
743     return binaryAnd(Other);
744   case Instruction::Or:
745     return binaryOr(Other);
746   // Note: floating point operations applied to abstract ranges are just
747   // ideal integer operations with a lossy representation
748   case Instruction::FAdd:
749     return add(Other);
750   case Instruction::FSub:
751     return sub(Other);
752   case Instruction::FMul:
753     return multiply(Other);
754   default:
755     // Conservatively return full set.
756     return ConstantRange(getBitWidth(), /*isFullSet=*/true);
757   }
758 }
759 
760 ConstantRange
add(const ConstantRange & Other) const761 ConstantRange::add(const ConstantRange &Other) const {
762   if (isEmptySet() || Other.isEmptySet())
763     return ConstantRange(getBitWidth(), /*isFullSet=*/false);
764   if (isFullSet() || Other.isFullSet())
765     return ConstantRange(getBitWidth(), /*isFullSet=*/true);
766 
767   APInt NewLower = getLower() + Other.getLower();
768   APInt NewUpper = getUpper() + Other.getUpper() - 1;
769   if (NewLower == NewUpper)
770     return ConstantRange(getBitWidth(), /*isFullSet=*/true);
771 
772   ConstantRange X = ConstantRange(std::move(NewLower), std::move(NewUpper));
773   if (X.isSizeStrictlySmallerThan(*this) ||
774       X.isSizeStrictlySmallerThan(Other))
775     // We've wrapped, therefore, full set.
776     return ConstantRange(getBitWidth(), /*isFullSet=*/true);
777   return X;
778 }
779 
addWithNoSignedWrap(const APInt & Other) const780 ConstantRange ConstantRange::addWithNoSignedWrap(const APInt &Other) const {
781   // Calculate the subset of this range such that "X + Other" is
782   // guaranteed not to wrap (overflow) for all X in this subset.
783   // makeGuaranteedNoWrapRegion will produce an exact NSW range since we are
784   // passing a single element range.
785   auto NSWRange = ConstantRange::makeGuaranteedNoWrapRegion(BinaryOperator::Add,
786                                       ConstantRange(Other),
787                                       OverflowingBinaryOperator::NoSignedWrap);
788   auto NSWConstrainedRange = intersectWith(NSWRange);
789 
790   return NSWConstrainedRange.add(ConstantRange(Other));
791 }
792 
793 ConstantRange
sub(const ConstantRange & Other) const794 ConstantRange::sub(const ConstantRange &Other) const {
795   if (isEmptySet() || Other.isEmptySet())
796     return ConstantRange(getBitWidth(), /*isFullSet=*/false);
797   if (isFullSet() || Other.isFullSet())
798     return ConstantRange(getBitWidth(), /*isFullSet=*/true);
799 
800   APInt NewLower = getLower() - Other.getUpper() + 1;
801   APInt NewUpper = getUpper() - Other.getLower();
802   if (NewLower == NewUpper)
803     return ConstantRange(getBitWidth(), /*isFullSet=*/true);
804 
805   ConstantRange X = ConstantRange(std::move(NewLower), std::move(NewUpper));
806   if (X.isSizeStrictlySmallerThan(*this) ||
807       X.isSizeStrictlySmallerThan(Other))
808     // We've wrapped, therefore, full set.
809     return ConstantRange(getBitWidth(), /*isFullSet=*/true);
810   return X;
811 }
812 
813 ConstantRange
multiply(const ConstantRange & Other) const814 ConstantRange::multiply(const ConstantRange &Other) const {
815   // TODO: If either operand is a single element and the multiply is known to
816   // be non-wrapping, round the result min and max value to the appropriate
817   // multiple of that element. If wrapping is possible, at least adjust the
818   // range according to the greatest power-of-two factor of the single element.
819 
820   if (isEmptySet() || Other.isEmptySet())
821     return ConstantRange(getBitWidth(), /*isFullSet=*/false);
822 
823   // Multiplication is signedness-independent. However different ranges can be
824   // obtained depending on how the input ranges are treated. These different
825   // ranges are all conservatively correct, but one might be better than the
826   // other. We calculate two ranges; one treating the inputs as unsigned
827   // and the other signed, then return the smallest of these ranges.
828 
829   // Unsigned range first.
830   APInt this_min = getUnsignedMin().zext(getBitWidth() * 2);
831   APInt this_max = getUnsignedMax().zext(getBitWidth() * 2);
832   APInt Other_min = Other.getUnsignedMin().zext(getBitWidth() * 2);
833   APInt Other_max = Other.getUnsignedMax().zext(getBitWidth() * 2);
834 
835   ConstantRange Result_zext = ConstantRange(this_min * Other_min,
836                                             this_max * Other_max + 1);
837   ConstantRange UR = Result_zext.truncate(getBitWidth());
838 
839   // If the unsigned range doesn't wrap, and isn't negative then it's a range
840   // from one positive number to another which is as good as we can generate.
841   // In this case, skip the extra work of generating signed ranges which aren't
842   // going to be better than this range.
843   if (!UR.isWrappedSet() &&
844       (UR.getUpper().isNonNegative() || UR.getUpper().isMinSignedValue()))
845     return UR;
846 
847   // Now the signed range. Because we could be dealing with negative numbers
848   // here, the lower bound is the smallest of the cartesian product of the
849   // lower and upper ranges; for example:
850   //   [-1,4) * [-2,3) = min(-1*-2, -1*2, 3*-2, 3*2) = -6.
851   // Similarly for the upper bound, swapping min for max.
852 
853   this_min = getSignedMin().sext(getBitWidth() * 2);
854   this_max = getSignedMax().sext(getBitWidth() * 2);
855   Other_min = Other.getSignedMin().sext(getBitWidth() * 2);
856   Other_max = Other.getSignedMax().sext(getBitWidth() * 2);
857 
858   auto L = {this_min * Other_min, this_min * Other_max,
859             this_max * Other_min, this_max * Other_max};
860   auto Compare = [](const APInt &A, const APInt &B) { return A.slt(B); };
861   ConstantRange Result_sext(std::min(L, Compare), std::max(L, Compare) + 1);
862   ConstantRange SR = Result_sext.truncate(getBitWidth());
863 
864   return UR.isSizeStrictlySmallerThan(SR) ? UR : SR;
865 }
866 
867 ConstantRange
smax(const ConstantRange & Other) const868 ConstantRange::smax(const ConstantRange &Other) const {
869   // X smax Y is: range(smax(X_smin, Y_smin),
870   //                    smax(X_smax, Y_smax))
871   if (isEmptySet() || Other.isEmptySet())
872     return ConstantRange(getBitWidth(), /*isFullSet=*/false);
873   APInt NewL = APIntOps::smax(getSignedMin(), Other.getSignedMin());
874   APInt NewU = APIntOps::smax(getSignedMax(), Other.getSignedMax()) + 1;
875   if (NewU == NewL)
876     return ConstantRange(getBitWidth(), /*isFullSet=*/true);
877   return ConstantRange(std::move(NewL), std::move(NewU));
878 }
879 
880 ConstantRange
umax(const ConstantRange & Other) const881 ConstantRange::umax(const ConstantRange &Other) const {
882   // X umax Y is: range(umax(X_umin, Y_umin),
883   //                    umax(X_umax, Y_umax))
884   if (isEmptySet() || Other.isEmptySet())
885     return ConstantRange(getBitWidth(), /*isFullSet=*/false);
886   APInt NewL = APIntOps::umax(getUnsignedMin(), Other.getUnsignedMin());
887   APInt NewU = APIntOps::umax(getUnsignedMax(), Other.getUnsignedMax()) + 1;
888   if (NewU == NewL)
889     return ConstantRange(getBitWidth(), /*isFullSet=*/true);
890   return ConstantRange(std::move(NewL), std::move(NewU));
891 }
892 
893 ConstantRange
smin(const ConstantRange & Other) const894 ConstantRange::smin(const ConstantRange &Other) const {
895   // X smin Y is: range(smin(X_smin, Y_smin),
896   //                    smin(X_smax, Y_smax))
897   if (isEmptySet() || Other.isEmptySet())
898     return ConstantRange(getBitWidth(), /*isFullSet=*/false);
899   APInt NewL = APIntOps::smin(getSignedMin(), Other.getSignedMin());
900   APInt NewU = APIntOps::smin(getSignedMax(), Other.getSignedMax()) + 1;
901   if (NewU == NewL)
902     return ConstantRange(getBitWidth(), /*isFullSet=*/true);
903   return ConstantRange(std::move(NewL), std::move(NewU));
904 }
905 
906 ConstantRange
umin(const ConstantRange & Other) const907 ConstantRange::umin(const ConstantRange &Other) const {
908   // X umin Y is: range(umin(X_umin, Y_umin),
909   //                    umin(X_umax, Y_umax))
910   if (isEmptySet() || Other.isEmptySet())
911     return ConstantRange(getBitWidth(), /*isFullSet=*/false);
912   APInt NewL = APIntOps::umin(getUnsignedMin(), Other.getUnsignedMin());
913   APInt NewU = APIntOps::umin(getUnsignedMax(), Other.getUnsignedMax()) + 1;
914   if (NewU == NewL)
915     return ConstantRange(getBitWidth(), /*isFullSet=*/true);
916   return ConstantRange(std::move(NewL), std::move(NewU));
917 }
918 
919 ConstantRange
udiv(const ConstantRange & RHS) const920 ConstantRange::udiv(const ConstantRange &RHS) const {
921   if (isEmptySet() || RHS.isEmptySet() || RHS.getUnsignedMax().isNullValue())
922     return ConstantRange(getBitWidth(), /*isFullSet=*/false);
923   if (RHS.isFullSet())
924     return ConstantRange(getBitWidth(), /*isFullSet=*/true);
925 
926   APInt Lower = getUnsignedMin().udiv(RHS.getUnsignedMax());
927 
928   APInt RHS_umin = RHS.getUnsignedMin();
929   if (RHS_umin.isNullValue()) {
930     // We want the lowest value in RHS excluding zero. Usually that would be 1
931     // except for a range in the form of [X, 1) in which case it would be X.
932     if (RHS.getUpper() == 1)
933       RHS_umin = RHS.getLower();
934     else
935       RHS_umin = 1;
936   }
937 
938   APInt Upper = getUnsignedMax().udiv(RHS_umin) + 1;
939 
940   // If the LHS is Full and the RHS is a wrapped interval containing 1 then
941   // this could occur.
942   if (Lower == Upper)
943     return ConstantRange(getBitWidth(), /*isFullSet=*/true);
944 
945   return ConstantRange(std::move(Lower), std::move(Upper));
946 }
947 
948 ConstantRange
binaryAnd(const ConstantRange & Other) const949 ConstantRange::binaryAnd(const ConstantRange &Other) const {
950   if (isEmptySet() || Other.isEmptySet())
951     return ConstantRange(getBitWidth(), /*isFullSet=*/false);
952 
953   // TODO: replace this with something less conservative
954 
955   APInt umin = APIntOps::umin(Other.getUnsignedMax(), getUnsignedMax());
956   if (umin.isAllOnesValue())
957     return ConstantRange(getBitWidth(), /*isFullSet=*/true);
958   return ConstantRange(APInt::getNullValue(getBitWidth()), std::move(umin) + 1);
959 }
960 
961 ConstantRange
binaryOr(const ConstantRange & Other) const962 ConstantRange::binaryOr(const ConstantRange &Other) const {
963   if (isEmptySet() || Other.isEmptySet())
964     return ConstantRange(getBitWidth(), /*isFullSet=*/false);
965 
966   // TODO: replace this with something less conservative
967 
968   APInt umax = APIntOps::umax(getUnsignedMin(), Other.getUnsignedMin());
969   if (umax.isNullValue())
970     return ConstantRange(getBitWidth(), /*isFullSet=*/true);
971   return ConstantRange(std::move(umax), APInt::getNullValue(getBitWidth()));
972 }
973 
974 ConstantRange
shl(const ConstantRange & Other) const975 ConstantRange::shl(const ConstantRange &Other) const {
976   if (isEmptySet() || Other.isEmptySet())
977     return ConstantRange(getBitWidth(), /*isFullSet=*/false);
978 
979   APInt max = getUnsignedMax();
980   APInt Other_umax = Other.getUnsignedMax();
981 
982   // there's overflow!
983   if (Other_umax.uge(max.countLeadingZeros()))
984     return ConstantRange(getBitWidth(), /*isFullSet=*/true);
985 
986   // FIXME: implement the other tricky cases
987 
988   APInt min = getUnsignedMin();
989   min <<= Other.getUnsignedMin();
990   max <<= Other_umax;
991 
992   return ConstantRange(std::move(min), std::move(max) + 1);
993 }
994 
995 ConstantRange
lshr(const ConstantRange & Other) const996 ConstantRange::lshr(const ConstantRange &Other) const {
997   if (isEmptySet() || Other.isEmptySet())
998     return ConstantRange(getBitWidth(), /*isFullSet=*/false);
999 
1000   APInt max = getUnsignedMax().lshr(Other.getUnsignedMin()) + 1;
1001   APInt min = getUnsignedMin().lshr(Other.getUnsignedMax());
1002   if (min == max)
1003     return ConstantRange(getBitWidth(), /*isFullSet=*/true);
1004 
1005   return ConstantRange(std::move(min), std::move(max));
1006 }
1007 
1008 ConstantRange
ashr(const ConstantRange & Other) const1009 ConstantRange::ashr(const ConstantRange &Other) const {
1010   if (isEmptySet() || Other.isEmptySet())
1011     return ConstantRange(getBitWidth(), /*isFullSet=*/false);
1012 
1013   // May straddle zero, so handle both positive and negative cases.
1014   // 'PosMax' is the upper bound of the result of the ashr
1015   // operation, when Upper of the LHS of ashr is a non-negative.
1016   // number. Since ashr of a non-negative number will result in a
1017   // smaller number, the Upper value of LHS is shifted right with
1018   // the minimum value of 'Other' instead of the maximum value.
1019   APInt PosMax = getSignedMax().ashr(Other.getUnsignedMin()) + 1;
1020 
1021   // 'PosMin' is the lower bound of the result of the ashr
1022   // operation, when Lower of the LHS is a non-negative number.
1023   // Since ashr of a non-negative number will result in a smaller
1024   // number, the Lower value of LHS is shifted right with the
1025   // maximum value of 'Other'.
1026   APInt PosMin = getSignedMin().ashr(Other.getUnsignedMax());
1027 
1028   // 'NegMax' is the upper bound of the result of the ashr
1029   // operation, when Upper of the LHS of ashr is a negative number.
1030   // Since 'ashr' of a negative number will result in a bigger
1031   // number, the Upper value of LHS is shifted right with the
1032   // maximum value of 'Other'.
1033   APInt NegMax = getSignedMax().ashr(Other.getUnsignedMax()) + 1;
1034 
1035   // 'NegMin' is the lower bound of the result of the ashr
1036   // operation, when Lower of the LHS of ashr is a negative number.
1037   // Since 'ashr' of a negative number will result in a bigger
1038   // number, the Lower value of LHS is shifted right with the
1039   // minimum value of 'Other'.
1040   APInt NegMin = getSignedMin().ashr(Other.getUnsignedMin());
1041 
1042   APInt max, min;
1043   if (getSignedMin().isNonNegative()) {
1044     // Upper and Lower of LHS are non-negative.
1045     min = PosMin;
1046     max = PosMax;
1047   } else if (getSignedMax().isNegative()) {
1048     // Upper and Lower of LHS are negative.
1049     min = NegMin;
1050     max = NegMax;
1051   } else {
1052     // Upper is non-negative and Lower is negative.
1053     min = NegMin;
1054     max = PosMax;
1055   }
1056   if (min == max)
1057     return ConstantRange(getBitWidth(), /*isFullSet=*/true);
1058 
1059   return ConstantRange(std::move(min), std::move(max));
1060 }
1061 
inverse() const1062 ConstantRange ConstantRange::inverse() const {
1063   if (isFullSet())
1064     return ConstantRange(getBitWidth(), /*isFullSet=*/false);
1065   if (isEmptySet())
1066     return ConstantRange(getBitWidth(), /*isFullSet=*/true);
1067   return ConstantRange(Upper, Lower);
1068 }
1069 
print(raw_ostream & OS) const1070 void ConstantRange::print(raw_ostream &OS) const {
1071   if (isFullSet())
1072     OS << "full-set";
1073   else if (isEmptySet())
1074     OS << "empty-set";
1075   else
1076     OS << "[" << Lower << "," << Upper << ")";
1077 }
1078 
1079 #if !defined(NDEBUG) || defined(LLVM_ENABLE_DUMP)
dump() const1080 LLVM_DUMP_METHOD void ConstantRange::dump() const {
1081   print(dbgs());
1082 }
1083 #endif
1084 
getConstantRangeFromMetadata(const MDNode & Ranges)1085 ConstantRange llvm::getConstantRangeFromMetadata(const MDNode &Ranges) {
1086   const unsigned NumRanges = Ranges.getNumOperands() / 2;
1087   assert(NumRanges >= 1 && "Must have at least one range!");
1088   assert(Ranges.getNumOperands() % 2 == 0 && "Must be a sequence of pairs");
1089 
1090   auto *FirstLow = mdconst::extract<ConstantInt>(Ranges.getOperand(0));
1091   auto *FirstHigh = mdconst::extract<ConstantInt>(Ranges.getOperand(1));
1092 
1093   ConstantRange CR(FirstLow->getValue(), FirstHigh->getValue());
1094 
1095   for (unsigned i = 1; i < NumRanges; ++i) {
1096     auto *Low = mdconst::extract<ConstantInt>(Ranges.getOperand(2 * i + 0));
1097     auto *High = mdconst::extract<ConstantInt>(Ranges.getOperand(2 * i + 1));
1098 
1099     // Note: unionWith will potentially create a range that contains values not
1100     // contained in any of the original N ranges.
1101     CR = CR.unionWith(ConstantRange(Low->getValue(), High->getValue()));
1102   }
1103 
1104   return CR;
1105 }
1106