mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-02 07:32:52 +00:00
Fix bugs introduced by constructor parameter order change.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@34357 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
3ebb2e0034
commit
cd6f2bfc26
@ -254,7 +254,7 @@ public:
|
|||||||
|
|
||||||
/// @brief Unary negation operator
|
/// @brief Unary negation operator
|
||||||
inline APInt operator-() const {
|
inline APInt operator-() const {
|
||||||
return APInt(0, BitWidth) - (*this);
|
return APInt(BitWidth, 0) - (*this);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// @brief Array-indexing support.
|
/// @brief Array-indexing support.
|
||||||
@ -469,7 +469,7 @@ public:
|
|||||||
APInt getLoBits(unsigned numBits) const;
|
APInt getLoBits(unsigned numBits) const;
|
||||||
|
|
||||||
/// @returns true if the argument APInt value is a power of two > 0.
|
/// @returns true if the argument APInt value is a power of two > 0.
|
||||||
inline bool isPowerOf2() const;
|
bool isPowerOf2() const;
|
||||||
|
|
||||||
/// @returns the number of zeros from the most significant bit to the first
|
/// @returns the number of zeros from the most significant bit to the first
|
||||||
/// one bits.
|
/// one bits.
|
||||||
@ -483,7 +483,7 @@ public:
|
|||||||
unsigned countPopulation() const;
|
unsigned countPopulation() const;
|
||||||
|
|
||||||
/// @returns the total number of bits.
|
/// @returns the total number of bits.
|
||||||
inline unsigned getNumBits() const {
|
inline unsigned getBitWidth() const {
|
||||||
return BitWidth;
|
return BitWidth;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -449,6 +449,7 @@ APInt& APInt::operator--() {
|
|||||||
/// @brief Addition assignment operator. Adds this APInt by the given APInt&
|
/// @brief Addition assignment operator. Adds this APInt by the given APInt&
|
||||||
/// RHS and assigns the result to this APInt.
|
/// RHS and assigns the result to this APInt.
|
||||||
APInt& APInt::operator+=(const APInt& RHS) {
|
APInt& APInt::operator+=(const APInt& RHS) {
|
||||||
|
assert(BitWidth == RHS.BitWidth && "Bit widths must be the same");
|
||||||
if (isSingleWord()) VAL += RHS.isSingleWord() ? RHS.VAL : RHS.pVal[0];
|
if (isSingleWord()) VAL += RHS.isSingleWord() ? RHS.VAL : RHS.pVal[0];
|
||||||
else {
|
else {
|
||||||
if (RHS.isSingleWord()) add_1(pVal, pVal, getNumWords(), RHS.VAL);
|
if (RHS.isSingleWord()) add_1(pVal, pVal, getNumWords(), RHS.VAL);
|
||||||
@ -469,6 +470,7 @@ APInt& APInt::operator+=(const APInt& RHS) {
|
|||||||
/// @brief Subtraction assignment operator. Subtracts this APInt by the given
|
/// @brief Subtraction assignment operator. Subtracts this APInt by the given
|
||||||
/// APInt &RHS and assigns the result to this APInt.
|
/// APInt &RHS and assigns the result to this APInt.
|
||||||
APInt& APInt::operator-=(const APInt& RHS) {
|
APInt& APInt::operator-=(const APInt& RHS) {
|
||||||
|
assert(BitWidth == RHS.BitWidth && "Bit widths must be the same");
|
||||||
if (isSingleWord())
|
if (isSingleWord())
|
||||||
VAL -= RHS.isSingleWord() ? RHS.VAL : RHS.pVal[0];
|
VAL -= RHS.isSingleWord() ? RHS.VAL : RHS.pVal[0];
|
||||||
else {
|
else {
|
||||||
@ -490,6 +492,7 @@ APInt& APInt::operator-=(const APInt& RHS) {
|
|||||||
/// @brief Multiplication assignment operator. Multiplies this APInt by the
|
/// @brief Multiplication assignment operator. Multiplies this APInt by the
|
||||||
/// given APInt& RHS and assigns the result to this APInt.
|
/// given APInt& RHS and assigns the result to this APInt.
|
||||||
APInt& APInt::operator*=(const APInt& RHS) {
|
APInt& APInt::operator*=(const APInt& RHS) {
|
||||||
|
assert(BitWidth == RHS.BitWidth && "Bit widths must be the same");
|
||||||
if (isSingleWord()) VAL *= RHS.isSingleWord() ? RHS.VAL : RHS.pVal[0];
|
if (isSingleWord()) VAL *= RHS.isSingleWord() ? RHS.VAL : RHS.pVal[0];
|
||||||
else {
|
else {
|
||||||
// one-based first non-zero bit position.
|
// one-based first non-zero bit position.
|
||||||
@ -521,6 +524,7 @@ APInt& APInt::operator*=(const APInt& RHS) {
|
|||||||
/// @brief Bitwise AND assignment operator. Performs bitwise AND operation on
|
/// @brief Bitwise AND assignment operator. Performs bitwise AND operation on
|
||||||
/// this APInt and the given APInt& RHS, assigns the result to this APInt.
|
/// this APInt and the given APInt& RHS, assigns the result to this APInt.
|
||||||
APInt& APInt::operator&=(const APInt& RHS) {
|
APInt& APInt::operator&=(const APInt& RHS) {
|
||||||
|
assert(BitWidth == RHS.BitWidth && "Bit widths must be the same");
|
||||||
if (isSingleWord()) {
|
if (isSingleWord()) {
|
||||||
if (RHS.isSingleWord()) VAL &= RHS.VAL;
|
if (RHS.isSingleWord()) VAL &= RHS.VAL;
|
||||||
else VAL &= RHS.pVal[0];
|
else VAL &= RHS.pVal[0];
|
||||||
@ -543,6 +547,7 @@ APInt& APInt::operator&=(const APInt& RHS) {
|
|||||||
/// @brief Bitwise OR assignment operator. Performs bitwise OR operation on
|
/// @brief Bitwise OR assignment operator. Performs bitwise OR operation on
|
||||||
/// this APInt and the given APInt& RHS, assigns the result to this APInt.
|
/// this APInt and the given APInt& RHS, assigns the result to this APInt.
|
||||||
APInt& APInt::operator|=(const APInt& RHS) {
|
APInt& APInt::operator|=(const APInt& RHS) {
|
||||||
|
assert(BitWidth == RHS.BitWidth && "Bit widths must be the same");
|
||||||
if (isSingleWord()) {
|
if (isSingleWord()) {
|
||||||
if (RHS.isSingleWord()) VAL |= RHS.VAL;
|
if (RHS.isSingleWord()) VAL |= RHS.VAL;
|
||||||
else VAL |= RHS.pVal[0];
|
else VAL |= RHS.pVal[0];
|
||||||
@ -563,6 +568,7 @@ APInt& APInt::operator|=(const APInt& RHS) {
|
|||||||
/// @brief Bitwise XOR assignment operator. Performs bitwise XOR operation on
|
/// @brief Bitwise XOR assignment operator. Performs bitwise XOR operation on
|
||||||
/// this APInt and the given APInt& RHS, assigns the result to this APInt.
|
/// this APInt and the given APInt& RHS, assigns the result to this APInt.
|
||||||
APInt& APInt::operator^=(const APInt& RHS) {
|
APInt& APInt::operator^=(const APInt& RHS) {
|
||||||
|
assert(BitWidth == RHS.BitWidth && "Bit widths must be the same");
|
||||||
if (isSingleWord()) {
|
if (isSingleWord()) {
|
||||||
if (RHS.isSingleWord()) VAL ^= RHS.VAL;
|
if (RHS.isSingleWord()) VAL ^= RHS.VAL;
|
||||||
else VAL ^= RHS.pVal[0];
|
else VAL ^= RHS.pVal[0];
|
||||||
@ -587,6 +593,7 @@ APInt& APInt::operator^=(const APInt& RHS) {
|
|||||||
/// @brief Bitwise AND operator. Performs bitwise AND operation on this APInt
|
/// @brief Bitwise AND operator. Performs bitwise AND operation on this APInt
|
||||||
/// and the given APInt& RHS.
|
/// and the given APInt& RHS.
|
||||||
APInt APInt::operator&(const APInt& RHS) const {
|
APInt APInt::operator&(const APInt& RHS) const {
|
||||||
|
assert(BitWidth == RHS.BitWidth && "Bit widths must be the same");
|
||||||
APInt API(RHS);
|
APInt API(RHS);
|
||||||
return API &= *this;
|
return API &= *this;
|
||||||
}
|
}
|
||||||
@ -594,6 +601,7 @@ APInt APInt::operator&(const APInt& RHS) const {
|
|||||||
/// @brief Bitwise OR operator. Performs bitwise OR operation on this APInt
|
/// @brief Bitwise OR operator. Performs bitwise OR operation on this APInt
|
||||||
/// and the given APInt& RHS.
|
/// and the given APInt& RHS.
|
||||||
APInt APInt::operator|(const APInt& RHS) const {
|
APInt APInt::operator|(const APInt& RHS) const {
|
||||||
|
assert(BitWidth == RHS.BitWidth && "Bit widths must be the same");
|
||||||
APInt API(RHS);
|
APInt API(RHS);
|
||||||
API |= *this;
|
API |= *this;
|
||||||
API.clearUnusedBits();
|
API.clearUnusedBits();
|
||||||
@ -603,6 +611,7 @@ APInt APInt::operator|(const APInt& RHS) const {
|
|||||||
/// @brief Bitwise XOR operator. Performs bitwise XOR operation on this APInt
|
/// @brief Bitwise XOR operator. Performs bitwise XOR operation on this APInt
|
||||||
/// and the given APInt& RHS.
|
/// and the given APInt& RHS.
|
||||||
APInt APInt::operator^(const APInt& RHS) const {
|
APInt APInt::operator^(const APInt& RHS) const {
|
||||||
|
assert(BitWidth == RHS.BitWidth && "Bit widths must be the same");
|
||||||
APInt API(RHS);
|
APInt API(RHS);
|
||||||
API ^= *this;
|
API ^= *this;
|
||||||
API.clearUnusedBits();
|
API.clearUnusedBits();
|
||||||
@ -625,6 +634,7 @@ bool APInt::operator !() const {
|
|||||||
/// @brief Multiplication operator. Multiplies this APInt by the given APInt&
|
/// @brief Multiplication operator. Multiplies this APInt by the given APInt&
|
||||||
/// RHS.
|
/// RHS.
|
||||||
APInt APInt::operator*(const APInt& RHS) const {
|
APInt APInt::operator*(const APInt& RHS) const {
|
||||||
|
assert(BitWidth == RHS.BitWidth && "Bit widths must be the same");
|
||||||
APInt API(RHS);
|
APInt API(RHS);
|
||||||
API *= *this;
|
API *= *this;
|
||||||
API.clearUnusedBits();
|
API.clearUnusedBits();
|
||||||
@ -633,6 +643,7 @@ APInt APInt::operator*(const APInt& RHS) const {
|
|||||||
|
|
||||||
/// @brief Addition operator. Adds this APInt by the given APInt& RHS.
|
/// @brief Addition operator. Adds this APInt by the given APInt& RHS.
|
||||||
APInt APInt::operator+(const APInt& RHS) const {
|
APInt APInt::operator+(const APInt& RHS) const {
|
||||||
|
assert(BitWidth == RHS.BitWidth && "Bit widths must be the same");
|
||||||
APInt API(*this);
|
APInt API(*this);
|
||||||
API += RHS;
|
API += RHS;
|
||||||
API.clearUnusedBits();
|
API.clearUnusedBits();
|
||||||
@ -641,6 +652,7 @@ APInt APInt::operator+(const APInt& RHS) const {
|
|||||||
|
|
||||||
/// @brief Subtraction operator. Subtracts this APInt by the given APInt& RHS
|
/// @brief Subtraction operator. Subtracts this APInt by the given APInt& RHS
|
||||||
APInt APInt::operator-(const APInt& RHS) const {
|
APInt APInt::operator-(const APInt& RHS) const {
|
||||||
|
assert(BitWidth == RHS.BitWidth && "Bit widths must be the same");
|
||||||
APInt API(*this);
|
APInt API(*this);
|
||||||
API -= RHS;
|
API -= RHS;
|
||||||
return API;
|
return API;
|
||||||
@ -823,10 +835,11 @@ std::string APInt::toString(uint8_t radix) const {
|
|||||||
}
|
}
|
||||||
|
|
||||||
APInt tmp(*this);
|
APInt tmp(*this);
|
||||||
APInt divisor(radix,64);
|
APInt divisor(tmp.getBitWidth(), radix);
|
||||||
|
APInt zero(tmp.getBitWidth(), 0);
|
||||||
if (tmp == 0)
|
if (tmp == 0)
|
||||||
result = "0";
|
result = "0";
|
||||||
else while (tmp != 0) {
|
else while (tmp.ne(zero)) {
|
||||||
APInt APdigit = APIntOps::urem(tmp,divisor);
|
APInt APdigit = APIntOps::urem(tmp,divisor);
|
||||||
unsigned digit = APdigit.getValue();
|
unsigned digit = APdigit.getValue();
|
||||||
assert(digit < radix && "urem failed");
|
assert(digit < radix && "urem failed");
|
||||||
@ -841,7 +854,7 @@ std::string APInt::toString(uint8_t radix) const {
|
|||||||
/// for an APInt of the specified bit-width and if isSign == true,
|
/// for an APInt of the specified bit-width and if isSign == true,
|
||||||
/// it should be largest signed value, otherwise unsigned value.
|
/// it should be largest signed value, otherwise unsigned value.
|
||||||
APInt APInt::getMaxValue(unsigned numBits, bool isSign) {
|
APInt APInt::getMaxValue(unsigned numBits, bool isSign) {
|
||||||
APInt APIVal(0, numBits);
|
APInt APIVal(numBits, 0);
|
||||||
APIVal.set();
|
APIVal.set();
|
||||||
if (isSign) APIVal.clear(numBits - 1);
|
if (isSign) APIVal.clear(numBits - 1);
|
||||||
return APIVal;
|
return APIVal;
|
||||||
@ -851,7 +864,7 @@ APInt APInt::getMaxValue(unsigned numBits, bool isSign) {
|
|||||||
/// an APInt of the given bit-width and if isSign == true,
|
/// an APInt of the given bit-width and if isSign == true,
|
||||||
/// it should be smallest signed value, otherwise zero.
|
/// it should be smallest signed value, otherwise zero.
|
||||||
APInt APInt::getMinValue(unsigned numBits, bool isSign) {
|
APInt APInt::getMinValue(unsigned numBits, bool isSign) {
|
||||||
APInt APIVal(0, numBits);
|
APInt APIVal(numBits, 0);
|
||||||
if (isSign) APIVal.set(numBits - 1);
|
if (isSign) APIVal.set(numBits - 1);
|
||||||
return APIVal;
|
return APIVal;
|
||||||
}
|
}
|
||||||
@ -909,7 +922,7 @@ unsigned APInt::countLeadingZeros() const {
|
|||||||
unsigned APInt::countTrailingZeros() const {
|
unsigned APInt::countTrailingZeros() const {
|
||||||
if (isSingleWord())
|
if (isSingleWord())
|
||||||
return CountTrailingZeros_64(~VAL & (VAL - 1));
|
return CountTrailingZeros_64(~VAL & (VAL - 1));
|
||||||
APInt Tmp = ~(*this) & ((*this) - APInt(BitWidth,1));
|
APInt Tmp( ~(*this) & ((*this) - APInt(BitWidth,1)) );
|
||||||
return getNumWords() * APINT_BITS_PER_WORD - Tmp.countLeadingZeros();
|
return getNumWords() * APINT_BITS_PER_WORD - Tmp.countLeadingZeros();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -932,21 +945,21 @@ unsigned APInt::countPopulation() const {
|
|||||||
APInt APInt::byteSwap() const {
|
APInt APInt::byteSwap() const {
|
||||||
assert(BitWidth >= 16 && BitWidth % 16 == 0 && "Cannot byteswap!");
|
assert(BitWidth >= 16 && BitWidth % 16 == 0 && "Cannot byteswap!");
|
||||||
if (BitWidth == 16)
|
if (BitWidth == 16)
|
||||||
return APInt(ByteSwap_16(VAL), BitWidth);
|
return APInt(BitWidth, ByteSwap_16(VAL));
|
||||||
else if (BitWidth == 32)
|
else if (BitWidth == 32)
|
||||||
return APInt(ByteSwap_32(VAL), BitWidth);
|
return APInt(BitWidth, ByteSwap_32(VAL));
|
||||||
else if (BitWidth == 48) {
|
else if (BitWidth == 48) {
|
||||||
uint64_t Tmp1 = ((VAL >> 32) << 16) | (VAL & 0xFFFF);
|
uint64_t Tmp1 = ((VAL >> 32) << 16) | (VAL & 0xFFFF);
|
||||||
Tmp1 = ByteSwap_32(Tmp1);
|
Tmp1 = ByteSwap_32(Tmp1);
|
||||||
uint64_t Tmp2 = (VAL >> 16) & 0xFFFF;
|
uint64_t Tmp2 = (VAL >> 16) & 0xFFFF;
|
||||||
Tmp2 = ByteSwap_16(Tmp2);
|
Tmp2 = ByteSwap_16(Tmp2);
|
||||||
return
|
return
|
||||||
APInt((Tmp1 & 0xff) | ((Tmp1<<16) & 0xffff00000000ULL) | (Tmp2 << 16),
|
APInt(BitWidth,
|
||||||
BitWidth);
|
(Tmp1 & 0xff) | ((Tmp1<<16) & 0xffff00000000ULL) | (Tmp2 << 16));
|
||||||
} else if (BitWidth == 64)
|
} else if (BitWidth == 64)
|
||||||
return APInt(ByteSwap_64(VAL), BitWidth);
|
return APInt(BitWidth, ByteSwap_64(VAL));
|
||||||
else {
|
else {
|
||||||
APInt Result(0, BitWidth);
|
APInt Result(BitWidth, 0);
|
||||||
char *pByte = (char*)Result.pVal;
|
char *pByte = (char*)Result.pVal;
|
||||||
for (unsigned i = 0; i < BitWidth / 8 / 2; ++i) {
|
for (unsigned i = 0; i < BitWidth / 8 / 2; ++i) {
|
||||||
char Tmp = pByte[i];
|
char Tmp = pByte[i];
|
||||||
@ -1123,6 +1136,7 @@ APInt APInt::shl(unsigned shiftAmt) const {
|
|||||||
/// Unsigned divide this APInt by APInt RHS.
|
/// Unsigned divide this APInt by APInt RHS.
|
||||||
/// @brief Unsigned division function for APInt.
|
/// @brief Unsigned division function for APInt.
|
||||||
APInt APInt::udiv(const APInt& RHS) const {
|
APInt APInt::udiv(const APInt& RHS) const {
|
||||||
|
assert(BitWidth == RHS.BitWidth && "Bit widths must be the same");
|
||||||
APInt API(*this);
|
APInt API(*this);
|
||||||
unsigned first = RHS.getActiveBits();
|
unsigned first = RHS.getActiveBits();
|
||||||
unsigned ylen = !first ? 0 : APInt::whichWord(first - 1) + 1;
|
unsigned ylen = !first ? 0 : APInt::whichWord(first - 1) + 1;
|
||||||
@ -1143,7 +1157,8 @@ APInt APInt::udiv(const APInt& RHS) const {
|
|||||||
} else if (xlen == 1)
|
} else if (xlen == 1)
|
||||||
API.pVal[0] /= RHS.isSingleWord() ? RHS.VAL : RHS.pVal[0];
|
API.pVal[0] /= RHS.isSingleWord() ? RHS.VAL : RHS.pVal[0];
|
||||||
else {
|
else {
|
||||||
APInt X(0, (xlen+1)*64), Y(0, ylen*64);
|
APInt X(BitWidth, 0);
|
||||||
|
APInt Y(BitWidth, 0);
|
||||||
if (unsigned nshift = 63 - (first - 1) % 64) {
|
if (unsigned nshift = 63 - (first - 1) % 64) {
|
||||||
Y = APIntOps::shl(RHS, nshift);
|
Y = APIntOps::shl(RHS, nshift);
|
||||||
X = APIntOps::shl(API, nshift);
|
X = APIntOps::shl(API, nshift);
|
||||||
@ -1161,6 +1176,7 @@ APInt APInt::udiv(const APInt& RHS) const {
|
|||||||
/// Unsigned remainder operation on APInt.
|
/// Unsigned remainder operation on APInt.
|
||||||
/// @brief Function for unsigned remainder operation.
|
/// @brief Function for unsigned remainder operation.
|
||||||
APInt APInt::urem(const APInt& RHS) const {
|
APInt APInt::urem(const APInt& RHS) const {
|
||||||
|
assert(BitWidth == RHS.BitWidth && "Bit widths must be the same");
|
||||||
APInt API(*this);
|
APInt API(*this);
|
||||||
unsigned first = RHS.getActiveBits();
|
unsigned first = RHS.getActiveBits();
|
||||||
unsigned ylen = !first ? 0 : APInt::whichWord(first - 1) + 1;
|
unsigned ylen = !first ? 0 : APInt::whichWord(first - 1) + 1;
|
||||||
@ -1178,7 +1194,7 @@ APInt APInt::urem(const APInt& RHS) const {
|
|||||||
else if (xlen == 1)
|
else if (xlen == 1)
|
||||||
API.pVal[0] %= RHS.isSingleWord() ? RHS.VAL : RHS.pVal[0];
|
API.pVal[0] %= RHS.isSingleWord() ? RHS.VAL : RHS.pVal[0];
|
||||||
else {
|
else {
|
||||||
APInt X(0, (xlen+1)*64), Y(0, ylen*64);
|
APInt X((xlen+1)*64, 0), Y(ylen*64, 0);
|
||||||
unsigned nshift = 63 - (first - 1) % 64;
|
unsigned nshift = 63 - (first - 1) % 64;
|
||||||
if (nshift) {
|
if (nshift) {
|
||||||
APIntOps::shl(Y, nshift);
|
APIntOps::shl(Y, nshift);
|
||||||
|
Loading…
Reference in New Issue
Block a user