mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-04 21:30:49 +00:00
silence some annoying gcc 4.3 warnings
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@36680 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
18a4c74136
commit
a5ae15ecb7
@ -1066,11 +1066,12 @@ APInt APInt::ashr(uint32_t shiftAmt) const {
|
|||||||
// If all the bits were shifted out, the result is, technically, undefined.
|
// If all the bits were shifted out, the result is, technically, undefined.
|
||||||
// We return -1 if it was negative, 0 otherwise. We check this early to avoid
|
// We return -1 if it was negative, 0 otherwise. We check this early to avoid
|
||||||
// issues in the algorithm below.
|
// issues in the algorithm below.
|
||||||
if (shiftAmt == BitWidth)
|
if (shiftAmt == BitWidth) {
|
||||||
if (isNegative())
|
if (isNegative())
|
||||||
return APInt(BitWidth, -1ULL);
|
return APInt(BitWidth, -1ULL);
|
||||||
else
|
else
|
||||||
return APInt(BitWidth, 0);
|
return APInt(BitWidth, 0);
|
||||||
|
}
|
||||||
|
|
||||||
// Create some space for the result.
|
// Create some space for the result.
|
||||||
uint64_t * val = new uint64_t[getNumWords()];
|
uint64_t * val = new uint64_t[getNumWords()];
|
||||||
@ -1108,7 +1109,7 @@ APInt APInt::ashr(uint32_t shiftAmt) const {
|
|||||||
|
|
||||||
// Deal with sign extenstion in the break word, and possibly the word before
|
// Deal with sign extenstion in the break word, and possibly the word before
|
||||||
// it.
|
// it.
|
||||||
if (isNegative())
|
if (isNegative()) {
|
||||||
if (wordShift > bitsInWord) {
|
if (wordShift > bitsInWord) {
|
||||||
if (breakWord > 0)
|
if (breakWord > 0)
|
||||||
val[breakWord-1] |=
|
val[breakWord-1] |=
|
||||||
@ -1117,6 +1118,7 @@ APInt APInt::ashr(uint32_t shiftAmt) const {
|
|||||||
} else
|
} else
|
||||||
val[breakWord] |= (~0ULL << (bitsInWord - wordShift));
|
val[breakWord] |= (~0ULL << (bitsInWord - wordShift));
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Remaining words are 0 or -1, just assign them.
|
// Remaining words are 0 or -1, just assign them.
|
||||||
uint64_t fillValue = (isNegative() ? -1ULL : 0);
|
uint64_t fillValue = (isNegative() ? -1ULL : 0);
|
||||||
@ -1128,11 +1130,12 @@ APInt APInt::ashr(uint32_t shiftAmt) const {
|
|||||||
/// Logical right-shift this APInt by shiftAmt.
|
/// Logical right-shift this APInt by shiftAmt.
|
||||||
/// @brief Logical right-shift function.
|
/// @brief Logical right-shift function.
|
||||||
APInt APInt::lshr(uint32_t shiftAmt) const {
|
APInt APInt::lshr(uint32_t shiftAmt) const {
|
||||||
if (isSingleWord())
|
if (isSingleWord()) {
|
||||||
if (shiftAmt == BitWidth)
|
if (shiftAmt == BitWidth)
|
||||||
return APInt(BitWidth, 0);
|
return APInt(BitWidth, 0);
|
||||||
else
|
else
|
||||||
return APInt(BitWidth, this->VAL >> shiftAmt);
|
return APInt(BitWidth, this->VAL >> shiftAmt);
|
||||||
|
}
|
||||||
|
|
||||||
// If all the bits were shifted out, the result is 0. This avoids issues
|
// If all the bits were shifted out, the result is 0. This avoids issues
|
||||||
// with shifting by the size of the integer type, which produces undefined
|
// with shifting by the size of the integer type, which produces undefined
|
||||||
@ -1760,10 +1763,10 @@ void APInt::fromString(uint32_t numbits, const char *str, uint32_t slen,
|
|||||||
bool isNeg = str[0] == '-';
|
bool isNeg = str[0] == '-';
|
||||||
if (isNeg)
|
if (isNeg)
|
||||||
str++, slen--;
|
str++, slen--;
|
||||||
assert(slen <= numbits || radix != 2 && "Insufficient bit width");
|
assert((slen <= numbits || radix != 2) && "Insufficient bit width");
|
||||||
assert(slen*3 <= numbits || radix != 8 && "Insufficient bit width");
|
assert((slen*3 <= numbits || radix != 8) && "Insufficient bit width");
|
||||||
assert(slen*4 <= numbits || radix != 16 && "Insufficient bit width");
|
assert((slen*4 <= numbits || radix != 16) && "Insufficient bit width");
|
||||||
assert((slen*64)/22 <= numbits || radix != 10 && "Insufficient bit width");
|
assert(((slen*64)/22 <= numbits || radix != 10) && "Insufficient bit width");
|
||||||
|
|
||||||
// Allocate memory
|
// Allocate memory
|
||||||
if (!isSingleWord())
|
if (!isSingleWord())
|
||||||
|
Loading…
Reference in New Issue
Block a user