mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-02-02 10:21:54 +00:00
Add getSignBit() and operator<<= into APInt for convenience.
llvm-svn: 35059
This commit is contained in:
parent
8a08bcfbe7
commit
9643d0a422
@ -386,6 +386,14 @@ public:
|
||||
/// @brief Left-shift function.
|
||||
APInt shl(uint32_t shiftAmt) const;
|
||||
|
||||
/// Left-shift this APInt by shiftAmt and
|
||||
/// assigns the result to this APInt.
|
||||
/// @brief Lef-shift assignment function.
|
||||
inline APInt& operator<<=(uint32_t shiftAmt) {
|
||||
*this = shl(shiftAmt);
|
||||
return *this;
|
||||
}
|
||||
|
||||
/// Signed divide this APInt by APInt RHS.
|
||||
/// @brief Signed division function for APInt.
|
||||
inline APInt sdiv(const APInt& RHS) const {
|
||||
@ -464,6 +472,14 @@ public:
|
||||
/// @brief Toggles a given bit to its opposite value.
|
||||
APInt& flip(uint32_t bitPosition);
|
||||
|
||||
inline void setWordToValue(uint32_t idx, uint64_t Val) {
|
||||
assert(idx < getNumWords() && "Invalid word array index");
|
||||
if (isSingleWord())
|
||||
VAL = Val;
|
||||
else
|
||||
pVal[idx] = Val;
|
||||
}
|
||||
|
||||
/// This function returns the number of active bits which is defined as the
|
||||
/// bit width minus the number of leading zeros. This is used in several
|
||||
/// computations to see how "wide" the value is.
|
||||
@ -551,6 +567,13 @@ public:
|
||||
return APInt(numBits, 0).set(numBits - 1);
|
||||
}
|
||||
|
||||
/// getSignBit - This is just a wrapper function of getSignedMinValue(), and
|
||||
/// it helps code readability when we want to get a SignBit.
|
||||
/// @brief Get the SignBit for a specific bit width.
|
||||
inline static APInt getSignBit(uint32_t BitWidth) {
|
||||
return getSignedMinValue(BitWidth);
|
||||
}
|
||||
|
||||
/// @returns the all-ones value for an APInt of the specified bit-width.
|
||||
/// @brief Get the all-ones value.
|
||||
static APInt getAllOnesValue(uint32_t numBits) {
|
||||
|
Loading…
x
Reference in New Issue
Block a user