15#ifndef LLVM_ADT_APINT_H
16#define LLVM_ADT_APINT_H
37template <
typename T,
typename Enable>
struct DenseMapInfo;
112 bool implicitTrunc =
false)
113 : BitWidth(numBits) {
114 if (!implicitTrunc) {
118 "Value must be 0 or -1 for signed 0-bit APInt");
121 "Value is not an N-bit signed value");
125 assert(val == 0 &&
"Value must be zero for unsigned 0-bit APInt");
128 "Value is not an N-bit unsigned value");
157 [[deprecated(
"Use other constructors of APInt")]]
186 memcpy(&U, &that.U,
sizeof(U));
221 APInt API(numBits, 0);
241 APInt Res(numBits, 0);
260 APInt Res(numBits, 0);
273 APInt Res(numBits, 0);
288 APInt Res(numBits, 0);
298 APInt Res(numBits, 0);
308 APInt Res(numBits, 0);
368 return (*
this)[BitNo] &&
popcount() == 1;
377 return countTrailingOnesSlowCase() == BitWidth;
384 return countLeadingZerosSlowCase() == BitWidth;
393 return countLeadingZerosSlowCase() == BitWidth - 1;
408 assert(BitWidth &&
"zero width values not allowed");
409 return U.VAL == ((
WordType(1) << (BitWidth - 1)) - 1);
411 return !
isNegative() && countTrailingOnesSlowCase() == BitWidth - 1;
426 assert(BitWidth &&
"zero width values not allowed");
427 return U.VAL == (
WordType(1) << (BitWidth - 1));
429 return isNegative() && countTrailingZerosSlowCase() == BitWidth - 1;
443 assert(BitWidth &&
"zero width values not allowed");
446 return countPopulationSlowCase() == 1;
451 assert(BitWidth &&
"zero width values not allowed");
457 return (LO + TZ) == BitWidth;
490 assert(numBits != 0 &&
"numBits must be non-zero");
491 assert(numBits <= BitWidth &&
"numBits out of range");
494 unsigned Ones = countTrailingOnesSlowCase();
495 return (numBits == Ones) &&
496 ((Ones + countLeadingZerosSlowCase()) == BitWidth);
505 unsigned Ones = countTrailingOnesSlowCase();
506 return (Ones > 0) && ((Ones + countLeadingZerosSlowCase()) == BitWidth);
514 unsigned Ones = countPopulationSlowCase();
515 unsigned LeadZ = countLeadingZerosSlowCase();
516 return (Ones + LeadZ + countTrailingZerosSlowCase()) == BitWidth;
526 unsigned Ones = countPopulationSlowCase();
527 unsigned LeadZ = countLeadingZerosSlowCase();
528 unsigned TrailZ = countTrailingZerosSlowCase();
529 if ((Ones + LeadZ + TrailZ) != BitWidth)
559 return I1 == I2.
zext(I1.getBitWidth());
624 BitWidth =
RHS.BitWidth;
634#ifdef EXPENSIVE_CHECKS
639 assert(
this != &that &&
"Self-move not supported");
645 memcpy(&U, &that.U,
sizeof(U));
647 BitWidth = that.BitWidth;
676 assert(BitWidth ==
RHS.BitWidth &&
"Bit widths must be the same");
680 andAssignSlowCase(
RHS);
706 assert(BitWidth ==
RHS.BitWidth &&
"Bit widths must be the same");
710 orAssignSlowCase(
RHS);
735 assert(BitWidth ==
RHS.BitWidth &&
"Bit widths must be the same");
739 xorAssignSlowCase(
RHS);
787 assert(ShiftAmt <= BitWidth &&
"Invalid shift amount");
789 if (ShiftAmt == BitWidth)
795 shlSlowCase(ShiftAmt);
830 R.ashrInPlace(ShiftAmt);
836 assert(ShiftAmt <= BitWidth &&
"Invalid shift amount");
839 if (ShiftAmt == BitWidth)
842 U.VAL = SExtVAL >> ShiftAmt;
846 ashrSlowCase(ShiftAmt);
854 R.lshrInPlace(shiftAmt);
860 assert(ShiftAmt <= BitWidth &&
"Invalid shift amount");
862 if (ShiftAmt == BitWidth)
868 lshrSlowCase(ShiftAmt);
882 return RelativeShift > 0 ?
lshr(RelativeShift) :
shl(-RelativeShift);
892 return RelativeShift > 0 ?
ashr(RelativeShift) :
shl(-RelativeShift);
911 R.ashrInPlace(ShiftAmt);
923 R.lshrInPlace(ShiftAmt);
953 return concatSlowCase(NewLSB);
1008 int64_t &Remainder);
1046 return (maskBit(bitPosition) & getWord(bitPosition)) != 0;
1058 assert(BitWidth ==
RHS.BitWidth &&
"Comparison requires equal bit widths");
1060 return U.VAL ==
RHS.U.VAL;
1061 return equalSlowCase(
RHS);
1251 assert(BitWidth ==
RHS.BitWidth &&
"Bit widths must be the same");
1253 return (U.VAL &
RHS.U.VAL) != 0;
1254 return intersectsSlowCase(
RHS);
1259 assert(BitWidth ==
RHS.BitWidth &&
"Bit widths must be the same");
1261 return (U.VAL & ~
RHS.U.VAL) == 0;
1262 return isSubsetOfSlowCase(
RHS);
1332 assert(BitPosition < BitWidth &&
"BitPosition out of range");
1333 WordType Mask = maskBit(BitPosition);
1337 U.pVal[whichWord(BitPosition)] |= Mask;
1356 assert(hiBit <= BitWidth &&
"hiBit out of range");
1357 assert(loBit <= BitWidth &&
"loBit out of range");
1358 if (loBit < hiBit) {
1369 assert(hiBit <= BitWidth &&
"hiBit out of range");
1370 assert(loBit <= hiBit &&
"loBit greater than hiBit");
1381 setBitsSlowCase(loBit, hiBit);
1393 return setBits(BitWidth - hiBits, BitWidth);
1408 assert(BitPosition < BitWidth &&
"BitPosition out of range");
1409 WordType Mask = ~maskBit(BitPosition);
1413 U.pVal[whichWord(BitPosition)] &= Mask;
1419 assert(HiBit <= BitWidth &&
"HiBit out of range");
1420 assert(LoBit <= HiBit &&
"LoBit greater than HiBit");
1425 Mask = ~(Mask << LoBit);
1431 clearBitsSlowCase(LoBit, HiBit);
1437 assert(loBits <= BitWidth &&
"More bits than bitwidth");
1444 assert(hiBits <= BitWidth &&
"More bits than bitwidth");
1458 flipAllBitsSlowCase();
1466 LLVM_ABI void flipBit(
unsigned bitPosition);
1475 LLVM_ABI void insertBits(
const APInt &SubBits,
unsigned bitPosition);
1482 unsigned bitPosition)
const;
1521 return numActiveBits ? whichWord(numActiveBits - 1) + 1 : 1;
1567 return int64_t(U.pVal[0]);
1604 return countLeadingZerosSlowCase();
1622 return countLeadingOnesSlowCase();
1643 return (TrailingZeros > BitWidth ? BitWidth : TrailingZeros);
1645 return countTrailingZerosSlowCase();
1660 return countTrailingOnesSlowCase();
1674 return countPopulationSlowCase();
1686 bool Signed,
bool formatAsCLiteral =
false,
1687 bool UpperCase =
true,
1688 bool InsertSeparators =
false)
const;
1693 toString(Str, Radix,
false,
false);
1725#ifdef HAS_IEE754_FLOAT128
1726 float128 bitsToQuad()
const {
1727 __uint128_t ul = ((__uint128_t)U.pVal[1] << 64) + U.pVal[0];
1780 LLVM_ABI unsigned nearestLogBase2()
const;
1817 LLVM_ABI static void tcSet(WordType *, WordType,
unsigned);
1820 LLVM_ABI static void tcAssign(WordType *,
const WordType *,
unsigned);
1823 LLVM_ABI static bool tcIsZero(
const WordType *,
unsigned);
1826 LLVM_ABI static int tcExtractBit(
const WordType *,
unsigned bit);
1832 LLVM_ABI static void tcExtract(WordType *,
unsigned dstCount,
1833 const WordType *,
unsigned srcBits,
1837 LLVM_ABI static void tcSetBit(WordType *,
unsigned bit);
1840 LLVM_ABI static void tcClearBit(WordType *,
unsigned bit);
1844 LLVM_ABI static unsigned tcLSB(
const WordType *,
unsigned n);
1845 LLVM_ABI static unsigned tcMSB(
const WordType *parts,
unsigned n);
1848 LLVM_ABI static void tcNegate(WordType *,
unsigned);
1851 LLVM_ABI static WordType tcAdd(WordType *,
const WordType *, WordType carry,
1854 LLVM_ABI static WordType tcAddPart(WordType *, WordType,
unsigned);
1857 LLVM_ABI static WordType tcSubtract(WordType *,
const WordType *,
1858 WordType carry,
unsigned);
1860 LLVM_ABI static WordType tcSubtractPart(WordType *, WordType,
unsigned);
1872 LLVM_ABI static int tcMultiplyPart(WordType *dst,
const WordType *src,
1873 WordType multiplier, WordType carry,
1874 unsigned srcParts,
unsigned dstParts,
1881 LLVM_ABI static int tcMultiply(WordType *,
const WordType *,
const WordType *,
1886 LLVM_ABI static void tcFullMultiply(WordType *,
const WordType *,
1887 const WordType *,
unsigned,
unsigned);
1898 LLVM_ABI static int tcDivide(WordType *lhs,
const WordType *rhs,
1899 WordType *remainder, WordType *scratch,
1904 LLVM_ABI static void tcShiftLeft(WordType *,
unsigned Words,
unsigned Count);
1908 LLVM_ABI static void tcShiftRight(WordType *,
unsigned Words,
unsigned Count);
1911 LLVM_ABI static int tcCompare(
const WordType *,
const WordType *,
unsigned);
1927#if !defined(NDEBUG) || defined(LLVM_ENABLE_DUMP)
1943 unsigned BitWidth = 1;
1949 friend DynamicAPInt;
1954 APInt(
uint64_t *val,
unsigned bits) : BitWidth(bits) { U.pVal = val; }
1959 static unsigned whichWord(
unsigned bitPosition) {
1960 return bitPosition / APINT_BITS_PER_WORD;
1964 static unsigned whichBit(
unsigned bitPosition) {
1965 return bitPosition % APINT_BITS_PER_WORD;
1974 static uint64_t maskBit(
unsigned bitPosition) {
1975 return 1ULL << whichBit(bitPosition);
1986 unsigned WordBits = ((
BitWidth - 1) % APINT_BITS_PER_WORD) + 1;
1989 uint64_t
mask = WORDTYPE_MAX >> (APINT_BITS_PER_WORD - WordBits);
1996 U.pVal[getNumWords() - 1] &=
mask;
2002 uint64_t getWord(
unsigned bitPosition)
const {
2003 return isSingleWord() ?
U.VAL :
U.pVal[whichWord(bitPosition)];
2009 void reallocate(
unsigned NewBitWidth);
2023 void fromString(
unsigned numBits, StringRef str, uint8_t radix);
2031 static void divide(
const WordType *
LHS,
unsigned lhsWords,
2032 const WordType *
RHS,
unsigned rhsWords, WordType *Quotient,
2033 WordType *Remainder);
2039 void initFromArray(ArrayRef<uint64_t> array);
2042 LLVM_ABI void initSlowCase(
const APInt &that);
2045 LLVM_ABI void shlSlowCase(
unsigned ShiftAmt);
2048 LLVM_ABI void lshrSlowCase(
unsigned ShiftAmt);
2051 LLVM_ABI void ashrSlowCase(
unsigned ShiftAmt);
2081 LLVM_ABI void setBitsSlowCase(
unsigned loBit,
unsigned hiBit);
2084 LLVM_ABI void clearBitsSlowCase(
unsigned LoBit,
unsigned HiBit);
2087 LLVM_ABI void flipAllBitsSlowCase();
2131 return std::move(b);
2151 return std::move(b);
2171 return std::move(b);
2201 return std::move(b);
2222 return std::move(b);
2250 return A.slt(
B) ?
A :
B;
2255 return A.sgt(
B) ?
A :
B;
2260 return A.ult(
B) ?
A :
B;
2265 return A.ugt(
B) ?
A :
B;
2270 return A.sge(
B) ? (
A -
B) : (
B -
A);
2275 return A.uge(
B) ? (
A -
B) : (
B -
A);
2345LLVM_ABI APInt RoundDoubleToAPInt(
double Double,
unsigned width);
2398LLVM_ABI std::optional<unsigned> GetMostSignificantDifferentBit(
const APInt &
A,
2413 bool MatchAllBits =
false);
2447LLVM_ABI hash_code hash_value(
const APInt &Arg);
2452 unsigned StoreBytes);
2457 unsigned LoadBytes);
2462 APInt V(
nullptr, 0);
2468 APInt V(
nullptr, 0);
2476 return LHS.getBitWidth() ==
RHS.getBitWidth() &&
LHS ==
RHS;
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
static void print(raw_ostream &Out, object::Archive::Kind Kind, T Val)
static constexpr unsigned long long mask(BlockVerifier::State S)
static GCRegistry::Add< ErlangGC > A("erlang", "erlang-compatible garbage collector")
static GCRegistry::Add< OcamlGC > B("ocaml", "ocaml 3.10-compatible GC")
raw_ostream & operator<<(raw_ostream &OS, const binary_le_impl< value_type > &BLE)
#define LLVM_UNLIKELY(EXPR)
#define LLVM_DUMP_METHOD
Mark debug helper function definitions like dump() that should not be stripped from debug builds.
static bool isSigned(unsigned int Opcode)
static KnownBits extractBits(unsigned BitWidth, const KnownBits &SrcOpKnown, const KnownBits &OffsetKnown, const KnownBits &WidthKnown)
static bool isZero(Value *V, const DataLayout &DL, DominatorTree *DT, AssumptionCache *AC)
static bool isAligned(const Value *Base, Align Alignment, const DataLayout &DL)
static bool isSplat(Value *V)
Return true if V is a splat of a value (which is used when multiplying a matrix with a scalar).
static const char * toString(MIToken::TokenKind TokenKind)
static uint64_t clearUnusedBits(uint64_t Val, unsigned Size)
static uint64_t umul_ov(uint64_t i, uint64_t j, bool &Overflow)
static TableGen::Emitter::OptClass< SkeletonEmitter > X("gen-skeleton-class", "Generate example skeleton class")
static unsigned getBitWidth(Type *Ty, const DataLayout &DL)
Returns the bitwidth of the given scalar or pointer type.
Class for arbitrary precision integers.
std::optional< uint64_t > tryZExtValue() const
Get zero extended value if possible.
static APInt getAllOnes(unsigned numBits)
Return an APInt of a specified width with all bits set.
bool slt(int64_t RHS) const
Signed less than comparison.
void clearBit(unsigned BitPosition)
Set a given bit to 0.
APInt relativeLShr(int RelativeShift) const
relative logical shift right
bool isNegatedPowerOf2() const
Check if this APInt's negated value is a power of two greater than zero.
LLVM_ABI APInt zext(unsigned width) const
Zero extend to a new width.
static APInt getSignMask(unsigned BitWidth)
Get the SignMask for a specific bit width.
bool isMinSignedValue() const
Determine if this is the smallest signed value.
APInt operator--(int)
Postfix decrement operator.
uint64_t getZExtValue() const
Get zero extended value.
uint64_t * pVal
Used to store the >64 bits integer value.
void setHighBits(unsigned hiBits)
Set the top hiBits bits.
unsigned popcount() const
Count the number of bits set.
void setBitsFrom(unsigned loBit)
Set the top bits starting from loBit.
APInt operator<<(const APInt &Bits) const
Left logical shift operator.
APInt operator<<(unsigned Bits) const
Left logical shift operator.
unsigned getActiveBits() const
Compute the number of active bits in the value.
bool sgt(int64_t RHS) const
Signed greater than comparison.
static APInt getMaxValue(unsigned numBits)
Gets maximum unsigned value of APInt for specific bit width.
void setBit(unsigned BitPosition)
Set the given bit to 1 whose position is given as "bitPosition".
bool operator[](unsigned bitPosition) const
Array-indexing support.
bool operator!=(const APInt &RHS) const
Inequality operator.
void toStringUnsigned(SmallVectorImpl< char > &Str, unsigned Radix=10) const
Considers the APInt to be unsigned and converts it into a string in the radix given.
APInt & operator&=(const APInt &RHS)
Bitwise AND assignment operator.
APInt abs() const
Get the absolute value.
unsigned ceilLogBase2() const
unsigned countLeadingOnes() const
APInt relativeLShl(int RelativeShift) const
relative logical shift left
APInt & operator=(const APInt &RHS)
Copy assignment operator.
bool sgt(const APInt &RHS) const
Signed greater than comparison.
bool isAllOnes() const
Determine if all bits are set. This is true for zero-width values.
APInt(unsigned numBits, uint64_t val, bool isSigned=false, bool implicitTrunc=false)
Create a new APInt of numBits width, initialized as val.
APInt & operator^=(uint64_t RHS)
Bitwise XOR assignment operator.
bool ugt(const APInt &RHS) const
Unsigned greater than comparison.
static APInt getBitsSet(unsigned numBits, unsigned loBit, unsigned hiBit)
Get a value with a block of bits set.
bool isZero() const
Determine if this value is zero, i.e. all bits are clear.
APInt & operator|=(uint64_t RHS)
Bitwise OR assignment operator.
bool isSignMask() const
Check if the APInt's value is returned by getSignMask.
static APInt floatToBits(float V)
Converts a float to APInt bits.
void setSignBit()
Set the sign bit to 1.
static constexpr unsigned APINT_WORD_SIZE
Byte size of a word.
unsigned getBitWidth() const
Return the number of bits in the APInt.
bool sle(uint64_t RHS) const
Signed less or equal comparison.
bool ult(const APInt &RHS) const
Unsigned less than comparison.
bool uge(uint64_t RHS) const
Unsigned greater or equal comparison.
bool operator!() const
Logical negation operation on this APInt returns true if zero, like normal integers.
static APInt getSignedMaxValue(unsigned numBits)
Gets maximum signed value of APInt for a specific bit width.
APInt & operator=(uint64_t RHS)
Assignment operator.
APInt relativeAShr(int RelativeShift) const
relative arithmetic shift right
APInt(const APInt &that)
Copy Constructor.
APInt & operator|=(const APInt &RHS)
Bitwise OR assignment operator.
bool isSingleWord() const
Determine if this APInt just has one word to store value.
bool operator==(uint64_t Val) const
Equality operator.
APInt operator++(int)
Postfix increment operator.
unsigned getNumWords() const
Get the number of words.
bool isMinValue() const
Determine if this is the smallest unsigned value.
APInt ashr(const APInt &ShiftAmt) const
Arithmetic right-shift function.
APInt()
Default constructor that creates an APInt with a 1-bit zero value.
static APInt getMinValue(unsigned numBits)
Gets minimum unsigned value of APInt for a specific bit width.
APInt(APInt &&that)
Move Constructor.
bool isNegative() const
Determine sign of this APInt.
APInt concat(const APInt &NewLSB) const
Concatenate the bits from "NewLSB" onto the bottom of *this.
bool intersects(const APInt &RHS) const
This operation tests if there are any pairs of corresponding bits between this APInt and RHS that are...
bool eq(const APInt &RHS) const
Equality comparison.
int32_t exactLogBase2() const
APInt & operator<<=(unsigned ShiftAmt)
Left-shift assignment function.
double roundToDouble() const
Converts this unsigned APInt to a double value.
void clearAllBits()
Set every bit to 0.
APInt relativeAShl(int RelativeShift) const
relative arithmetic shift left
void ashrInPlace(unsigned ShiftAmt)
Arithmetic right-shift this APInt by ShiftAmt in place.
bool sle(const APInt &RHS) const
Signed less or equal comparison.
void negate()
Negate this APInt in place.
static WordType tcDecrement(WordType *dst, unsigned parts)
Decrement a bignum in-place. Return the borrow flag.
unsigned countr_zero() const
Count the number of trailing zero bits.
bool isSignedIntN(unsigned N) const
Check if this APInt has an N-bits signed integer value.
unsigned getNumSignBits() const
Computes the number of leading bits of this APInt that are equal to its sign bit.
bool isOneBitSet(unsigned BitNo) const
Determine if this APInt Value only has the specified bit set.
unsigned countl_zero() const
The APInt version of std::countl_zero.
bool operator==(const APInt &RHS) const
Equality operator.
APInt shl(const APInt &ShiftAmt) const
Left-shift function.
static APInt getSignedMinValue(unsigned numBits)
Gets minimum signed value of APInt for a specific bit width.
LLVM_ABI friend hash_code hash_value(const APInt &Arg)
Overload to compute a hash_code for an APInt value.
bool isShiftedMask(unsigned &MaskIdx, unsigned &MaskLen) const
Return true if this APInt value contains a non-empty sequence of ones with the remainder zero.
static constexpr WordType WORDTYPE_MAX
static LLVM_ABI WordType tcSubtractPart(WordType *, WordType, unsigned)
DST -= RHS. Returns the carry flag.
void setBitsWithWrap(unsigned loBit, unsigned hiBit)
Set the bits from loBit (inclusive) to hiBit (exclusive) to 1.
APInt lshr(const APInt &ShiftAmt) const
Logical right-shift function.
bool isNonPositive() const
Determine if this APInt Value is non-positive (<= 0).
unsigned countTrailingZeros() const
unsigned getSignificantBits() const
Get the minimum bit size for this signed APInt.
unsigned countLeadingZeros() const
bool isStrictlyPositive() const
Determine if this APInt Value is positive.
void flipAllBits()
Toggle every bit to its opposite value.
static unsigned getNumWords(unsigned BitWidth)
Get the number of words.
bool needsCleanup() const
Returns whether this instance allocated memory.
unsigned countl_one() const
Count the number of leading one bits.
void clearLowBits(unsigned loBits)
Set bottom loBits bits to 0.
unsigned logBase2() const
static APInt getZeroWidth()
Return an APInt zero bits wide.
double signedRoundToDouble() const
Converts this signed APInt to a double value.
bool isShiftedMask() const
Return true if this APInt value contains a non-empty sequence of ones with the remainder zero.
float bitsToFloat() const
Converts APInt bits to a float.
static constexpr unsigned APINT_BITS_PER_WORD
Bits in a word.
uint64_t getLimitedValue(uint64_t Limit=UINT64_MAX) const
If this value is smaller than the specified limit, return it, otherwise return the limit value.
bool ule(uint64_t RHS) const
Unsigned less or equal comparison.
APInt ashr(unsigned ShiftAmt) const
Arithmetic right-shift function.
void setAllBits()
Set every bit to 1.
uint64_t VAL
Used to store the <= 64 bits integer value.
bool ugt(uint64_t RHS) const
Unsigned greater than comparison.
bool sge(int64_t RHS) const
Signed greater or equal comparison.
bool getBoolValue() const
Convert APInt to a boolean value.
static APInt doubleToBits(double V)
Converts a double to APInt bits.
bool isMask(unsigned numBits) const
APInt & operator=(APInt &&that)
Move assignment operator.
static WordType tcIncrement(WordType *dst, unsigned parts)
Increment a bignum in-place. Return the carry flag.
APInt & operator^=(const APInt &RHS)
Bitwise XOR assignment operator.
bool isMaxSignedValue() const
Determine if this is the largest signed value.
bool isNonNegative() const
Determine if this APInt Value is non-negative (>= 0)
bool ule(const APInt &RHS) const
Unsigned less or equal comparison.
void setBits(unsigned loBit, unsigned hiBit)
Set the bits from loBit (inclusive) to hiBit (exclusive) to 1.
APInt shl(unsigned shiftAmt) const
Left-shift function.
double bitsToDouble() const
Converts APInt bits to a double.
bool isSubsetOf(const APInt &RHS) const
This operation checks that all bits set in this APInt are also set in RHS.
bool isPowerOf2() const
Check if this APInt's value is a power of two greater than zero.
unsigned getActiveWords() const
Compute the number of active words in the value of this APInt.
bool ne(const APInt &RHS) const
Inequality comparison.
static bool isSameValue(const APInt &I1, const APInt &I2)
Determine if two APInts have the same value, after zero-extending one of them (if needed!...
static APInt getLowBitsSet(unsigned numBits, unsigned loBitsSet)
Constructs an APInt value that has the bottom loBitsSet bits set.
void clearBits(unsigned LoBit, unsigned HiBit)
Clear the bits from LoBit (inclusive) to HiBit (exclusive) to 0.
bool isSignBitSet() const
Determine if sign bit of this APInt is set.
static LLVM_ABI WordType tcAddPart(WordType *, WordType, unsigned)
DST += RHS. Returns the carry flag.
const uint64_t * getRawData() const
This function returns a pointer to the internal storage of the APInt.
bool slt(const APInt &RHS) const
Signed less than comparison.
static APInt getHighBitsSet(unsigned numBits, unsigned hiBitsSet)
Constructs an APInt value that has the top hiBitsSet bits set.
static APInt getZero(unsigned numBits)
Get the '0' value for the specified bit-width.
void setLowBits(unsigned loBits)
Set the bottom loBits bits.
bool isIntN(unsigned N) const
Check if this APInt has an N-bits unsigned integer value.
unsigned countTrailingOnes() const
bool sge(const APInt &RHS) const
Signed greater or equal comparison.
std::optional< int64_t > trySExtValue() const
Get sign extended value if possible.
APInt & operator&=(uint64_t RHS)
Bitwise AND assignment operator.
LLVM_ABI double roundToDouble(bool isSigned) const
Converts this APInt to a double value.
bool isOne() const
Determine if this is a value of 1.
static APInt getBitsSetFrom(unsigned numBits, unsigned loBit)
Constructs an APInt value that has a contiguous range of bits set.
static APInt getOneBitSet(unsigned numBits, unsigned BitNo)
Return an APInt with exactly one bit set in the result.
void clearHighBits(unsigned hiBits)
Set top hiBits bits to 0.
int64_t getSExtValue() const
Get sign extended value.
void lshrInPlace(unsigned ShiftAmt)
Logical right-shift this APInt by ShiftAmt in place.
APInt lshr(unsigned shiftAmt) const
Logical right-shift function.
unsigned countr_one() const
Count the number of trailing one bits.
static APInt getBitsSetWithWrap(unsigned numBits, unsigned loBit, unsigned hiBit)
Wrap version of getBitsSet.
bool isSignBitClear() const
Determine if sign bit of this APInt is clear.
bool uge(const APInt &RHS) const
Unsigned greater or equal comparison.
void setBitVal(unsigned BitPosition, bool BitValue)
Set a given bit to a given value.
void clearSignBit()
Set the sign bit to 0.
bool isMaxValue() const
Determine if this is the largest unsigned value.
void toStringSigned(SmallVectorImpl< char > &Str, unsigned Radix=10) const
Considers the APInt to be signed and converts it into a string in the radix given.
bool ult(uint64_t RHS) const
Unsigned less than comparison.
bool operator!=(uint64_t Val) const
Inequality operator.
ArrayRef - Represent a constant reference to an array (0 or more elements consecutively in memory),...
This class provides support for dynamic arbitrary-precision arithmetic.
FoldingSetNodeID - This class is used to gather all the unique data bits of a node.
This class consists of common code factored out of the SmallVector class to reduce code duplication b...
StringRef - Represent a constant reference to a string, i.e.
An opaque object representing a hash code.
This class implements an extremely fast bulk output stream that can only output to a stream.
LLVM_ABI std::error_code fromString(StringRef String, Metadata &HSAMetadata)
Converts String to HSAMetadata.
float RoundAPIntToFloat(const APInt &APIVal)
Converts the given APInt to a float value.
double RoundAPIntToDouble(const APInt &APIVal)
Converts the given APInt to a double value.
const APInt & smin(const APInt &A, const APInt &B)
Determine the smaller of two APInts considered to be signed.
const APInt & smax(const APInt &A, const APInt &B)
Determine the larger of two APInts considered to be signed.
const APInt & umin(const APInt &A, const APInt &B)
Determine the smaller of two APInts considered to be unsigned.
APInt RoundFloatToAPInt(float Float, unsigned width)
Converts a float value into a APInt.
LLVM_ABI APInt RoundDoubleToAPInt(double Double, unsigned width)
Converts the given double value into a APInt.
APInt abds(const APInt &A, const APInt &B)
Determine the absolute difference of two APInts considered to be signed.
double RoundSignedAPIntToDouble(const APInt &APIVal)
Converts the given APInt to a double value.
APInt abdu(const APInt &A, const APInt &B)
Determine the absolute difference of two APInts considered to be unsigned.
float RoundSignedAPIntToFloat(const APInt &APIVal)
Converts the given APInt to a float value.
const APInt & umax(const APInt &A, const APInt &B)
Determine the larger of two APInts considered to be unsigned.
@ C
The default llvm calling convention, compatible with C.
This is an optimization pass for GlobalISel generic memory operations.
void dump(const SparseBitVector< ElementSize > &LHS, raw_ostream &out)
constexpr T rotr(T V, int R)
APInt operator&(APInt a, const APInt &b)
APInt operator*(APInt a, uint64_t RHS)
int countr_one(T Value)
Count the number of ones from the least significant bit to the first zero bit.
bool operator!=(uint64_t V1, const APInt &V2)
LLVM_ATTRIBUTE_ALWAYS_INLINE DynamicAPInt & operator+=(DynamicAPInt &A, int64_t B)
constexpr bool isUIntN(unsigned N, uint64_t x)
Checks if an unsigned integer fits into the given (dynamic) bit width.
LLVM_ATTRIBUTE_ALWAYS_INLINE DynamicAPInt & operator-=(DynamicAPInt &A, int64_t B)
constexpr bool isPowerOf2_64(uint64_t Value)
Return true if the argument is a power of two > 0 (64 bit edition.)
APInt operator~(APInt v)
Unary bitwise complement operator.
constexpr int popcount(T Value) noexcept
Count the number of set bits in a value.
int countr_zero(T Val)
Count number of 0's from the least significant bit to the most stopping at the first 1.
constexpr bool isShiftedMask_64(uint64_t Value)
Return true if the argument contains a non-empty sequence of ones with the remainder zero (64 bit ver...
LLVM_ATTRIBUTE_ALWAYS_INLINE DynamicAPInt & operator*=(DynamicAPInt &A, int64_t B)
int countl_zero(T Val)
Count number of 0's from the most significant bit to the least stopping at the first 1.
APInt operator^(APInt a, const APInt &b)
constexpr bool isMask_64(uint64_t Value)
Return true if the argument is a non-empty sequence of ones starting at the least significant bit wit...
FunctionAddr VTableAddr Count
int countl_one(T Value)
Count the number of ones from the most significant bit to the first zero bit.
LLVM_ATTRIBUTE_VISIBILITY_DEFAULT AnalysisKey InnerAnalysisManagerProxy< AnalysisManagerT, IRUnitT, ExtraArgTs... >::Key
To bit_cast(const From &from) noexcept
constexpr bool isIntN(unsigned N, int64_t x)
Checks if an signed integer fits into the given (dynamic) bit width.
constexpr T reverseBits(T Val)
Reverse the bits in Val.
constexpr int64_t SignExtend64(uint64_t x)
Sign-extend the number in the bottom B bits of X to a 64-bit integer.
APInt operator+(APInt a, const APInt &b)
APInt operator|(APInt a, const APInt &b)
constexpr T rotl(T V, int R)
@ Keep
No function return thunk.
This struct is a compact representation of a valid (non-zero power of two) alignment.
static APInt getEmptyKey()
static APInt getTombstoneKey()
static bool isEqual(const APInt &LHS, const APInt &RHS)
static LLVM_ABI unsigned getHashValue(const APInt &Key)
An information struct used to provide DenseMap with the various necessary components for a given valu...