mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-14 16:33:28 +00:00
ADT: Correct APInt::getActiveWords for zero values
PR15138 was opened because of a segfault in the Bitcode writer. The actual issue ended up being a bug in APInt where calls to APInt::getActiveWords returns a bogus value when the APInt value is 0. This patch fixes the problem by ensuring that getActiveWords returns 1 for 0 valued APInts. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@174641 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
def0c1f756
commit
35b1423ee6
@ -1191,7 +1191,8 @@ public:
|
|||||||
/// APInt. This is used in conjunction with getActiveData to extract the raw
|
/// APInt. This is used in conjunction with getActiveData to extract the raw
|
||||||
/// value of the APInt.
|
/// value of the APInt.
|
||||||
unsigned getActiveWords() const {
|
unsigned getActiveWords() const {
|
||||||
return whichWord(getActiveBits()-1) + 1;
|
unsigned numActiveBits = getActiveBits();
|
||||||
|
return numActiveBits ? whichWord(numActiveBits - 1) + 1 : 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Computes the minimum bit width for this APInt while considering it to be
|
/// Computes the minimum bit width for this APInt while considering it to be
|
||||||
|
@ -56,6 +56,14 @@ TEST(APIntTest, i33_Count) {
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
TEST(APIntTest, i65_Count) {
|
TEST(APIntTest, i65_Count) {
|
||||||
|
APInt i65(65, 0, true);
|
||||||
|
EXPECT_EQ(65u, i65.countLeadingZeros());
|
||||||
|
EXPECT_EQ(0u, i65.countLeadingOnes());
|
||||||
|
EXPECT_EQ(0u, i65.getActiveBits());
|
||||||
|
EXPECT_EQ(1u, i65.getActiveWords());
|
||||||
|
EXPECT_EQ(65u, i65.countTrailingZeros());
|
||||||
|
EXPECT_EQ(0u, i65.countPopulation());
|
||||||
|
|
||||||
APInt i65minus(65, 0, true);
|
APInt i65minus(65, 0, true);
|
||||||
i65minus.setBit(64);
|
i65minus.setBit(64);
|
||||||
EXPECT_EQ(0u, i65minus.countLeadingZeros());
|
EXPECT_EQ(0u, i65minus.countLeadingZeros());
|
||||||
|
Loading…
x
Reference in New Issue
Block a user