Add lsb index to V3Number::setMask (#5522)

This commit is contained in:
Geza Lore 2024-10-08 13:15:36 +01:00 committed by GitHub
parent b873c23cf2
commit 8f1ea09558
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
5 changed files with 11 additions and 14 deletions

View File

@ -1162,11 +1162,10 @@ class ConstVisitor final : public VNVisitor {
} else if (const AstShiftL* const shiftp = VN_CAST(nodep->rhsp(), ShiftL)) { } else if (const AstShiftL* const shiftp = VN_CAST(nodep->rhsp(), ShiftL)) {
if (const AstConst* const scp = VN_CAST(shiftp->rhsp(), Const)) { if (const AstConst* const scp = VN_CAST(shiftp->rhsp(), Const)) {
// Check if mask is full over the non-zero bits // Check if mask is full over the non-zero bits
V3Number maskLo{nodep, nodep->width()}; V3Number mask{nodep, nodep->width()};
V3Number maskHi{nodep, nodep->width()}; const uint32_t shiftAmount = scp->num().toUInt();
maskLo.setMask(nodep->width() - scp->num().toUInt()); mask.setMask(nodep->width() - shiftAmount, shiftAmount);
maskHi.opShiftL(maskLo, scp->num()); return checkMask(mask);
return checkMask(maskHi);
} }
} }
return false; return false;

View File

@ -531,10 +531,7 @@ class DelayedVisitor final : public VNVisitor {
// Constant mask we can compute here // Constant mask we can compute here
if (AstConst* const cLsbp = VN_CAST(sLsbp, Const)) { if (AstConst* const cLsbp = VN_CAST(sLsbp, Const)) {
AstConst* const cp = new AstConst{flp, AstConst::DTyped{}, eDTypep}; AstConst* const cp = new AstConst{flp, AstConst::DTyped{}, eDTypep};
cp->num().setAllBits0(); cp->num().setMask(sWidthp->toSInt(), cLsbp->toSInt());
const int lsb = cLsbp->toSInt();
const int msb = lsb + sWidthp->toSInt() - 1;
for (int bit = lsb; bit <= msb; ++bit) cp->num().setBit(bit, '1');
return cp; return cp;
} }

View File

@ -551,7 +551,7 @@ class ExpandVisitor final : public VNVisitor {
const int lsb = lhsp->lsbConst(); const int lsb = lhsp->lsbConst();
const int msb = lhsp->msbConst(); const int msb = lhsp->msbConst();
V3Number maskset{nodep, destp->widthMin()}; V3Number maskset{nodep, destp->widthMin()};
for (int bit = lsb; bit < (msb + 1); bit++) maskset.setBit(bit, 1); maskset.setMask(msb + 1 - lsb, lsb);
V3Number maskold{nodep, destp->widthMin()}; V3Number maskold{nodep, destp->widthMin()};
maskold.opNot(maskset); maskold.opNot(maskset);
if (destwide) { if (destwide) {
@ -654,7 +654,7 @@ class ExpandVisitor final : public VNVisitor {
fixCloneLvalue(oldvalp); fixCloneLvalue(oldvalp);
V3Number maskwidth{nodep, destp->widthMin()}; V3Number maskwidth{nodep, destp->widthMin()};
for (int bit = 0; bit < lhsp->widthConst(); bit++) maskwidth.setBit(bit, 1); maskwidth.setMask(lhsp->widthConst());
if (destp->isQuad() && !rhsp->isQuad()) rhsp = new AstCCast{nfl, rhsp, nodep}; if (destp->isQuad() && !rhsp->isQuad()) rhsp = new AstCCast{nfl, rhsp, nodep};
if (!ones) { if (!ones) {

View File

@ -511,9 +511,9 @@ V3Number& V3Number::setValue1() {
return *this; return *this;
} }
V3Number& V3Number::setMask(int nbits) { V3Number& V3Number::setMask(int nbits, int lsb) {
setZero(); setZero();
for (int bit = 0; bit < nbits; bit++) setBit(bit, 1); for (int bit = lsb; bit < lsb + nbits; bit++) setBit(bit, 1);
return *this; return *this;
} }

View File

@ -576,7 +576,8 @@ public:
V3Number& setAllBits0(); V3Number& setAllBits0();
V3Number& setAllBits1(); V3Number& setAllBits1();
V3Number& setValue1(); V3Number& setValue1();
V3Number& setMask(int nbits); // IE if nbits=1, then 0b1, if 2->0b11, if 3->0b111 etc // IE if nbits=1, then 0b1, if 2->0b11, if 3->0b111 etc
V3Number& setMask(int nbits, int lsb = 0);
// ACCESSORS // ACCESSORS
string ascii(bool prefixed = true, bool cleanVerilog = false) const VL_MT_STABLE; string ascii(bool prefixed = true, bool cleanVerilog = false) const VL_MT_STABLE;