Omit AstNode::m_editCount in release build

This is only a debugging aid at this point, so compile out of the
release build. This reduces peak memory consumption by 4-5%. We still
keep the global counters to detect the tree have changed, to avoid
unnecessary dumps.
This commit is contained in:
Geza Lore 2022-09-24 21:18:43 +01:00
parent 10796457d2
commit 9a20a258f5
2 changed files with 13 additions and 7 deletions

View File

@ -1443,13 +1443,15 @@ class AstNode VL_NOT_FINAL {
AstNodeDType* m_dtypep = nullptr; // Data type of output or assignment (etc) AstNodeDType* m_dtypep = nullptr; // Data type of output or assignment (etc)
AstNode* m_headtailp; // When at begin/end of list, the opposite end of the list AstNode* m_headtailp; // When at begin/end of list, the opposite end of the list
FileLine* m_fileline; // Where it was declared FileLine* m_fileline; // Where it was declared
#ifdef VL_DEBUG
// Only keep track of the edit count in the node in the debug build.
// In the release build we will take the space saving instead.
uint64_t m_editCount; // When it was last edited uint64_t m_editCount; // When it was last edited
#endif
static uint64_t s_editCntGbl; // Global edit counter static uint64_t s_editCntGbl; // Global edit counter
// Global edit counter, last value for printing * near node #s static uint64_t s_editCntLast; // Last committed value of global edit counter
static uint64_t s_editCntLast;
AstNode* m_clonep AstNode* m_clonep = nullptr; // Pointer to clone/source of node (only for *LAST* cloneTree())
= nullptr; // Pointer to clone of/ source of this module (for *LAST* cloneTree() ONLY)
static int s_cloneCntGbl; // Count of which userp is set static int s_cloneCntGbl; // Count of which userp is set
// This member ordering both allows 64 bit alignment and puts associated data together // This member ordering both allows 64 bit alignment and puts associated data together
@ -1720,10 +1722,14 @@ public:
static void user5ClearTree() { VNUser5InUse::clear(); } // Clear userp()'s across the entire tree static void user5ClearTree() { VNUser5InUse::clear(); } // Clear userp()'s across the entire tree
// clang-format on // clang-format on
#ifdef VL_DEBUG
uint64_t editCount() const { return m_editCount; } uint64_t editCount() const { return m_editCount; }
void editCountInc() { void editCountInc() {
m_editCount = ++s_editCntGbl; // Preincrement, so can "watch AstNode::s_editCntGbl=##" m_editCount = ++s_editCntGbl; // Preincrement, so can "watch AstNode::s_editCntGbl=##"
} }
#else
void editCountInc() { ++s_editCntGbl; }
#endif
static uint64_t editCountLast() { return s_editCntLast; } static uint64_t editCountLast() { return s_editCntLast; }
static uint64_t editCountGbl() { return s_editCntGbl; } static uint64_t editCountGbl() { return s_editCntGbl; }
static void editCountSetLast() { s_editCntLast = editCountGbl(); } static void editCountSetLast() { s_editCntLast = editCountGbl(); }

View File

@ -1266,10 +1266,10 @@ static std::string nodeAddr(const AstNode* nodep) {
} }
void AstNode::dump(std::ostream& str) const { void AstNode::dump(std::ostream& str) const {
str << typeName() << " " str << typeName() << " " << nodeAddr(this)
<< nodeAddr(this) #ifdef VL_DEBUG
//<< " " << nodeAddr(m_backp)
<< " <e" << std::dec << editCount() << ((editCount() >= editCountLast()) ? "#>" : ">") << " <e" << std::dec << editCount() << ((editCount() >= editCountLast()) ? "#>" : ">")
#endif
<< " {" << fileline()->filenameLetters() << std::dec << fileline()->lastLineno() << " {" << fileline()->filenameLetters() << std::dec << fileline()->lastLineno()
<< fileline()->firstColumnLetters() << "}"; << fileline()->firstColumnLetters() << "}";
if (user1p()) str << " u1=" << nodeAddr(user1p()); if (user1p()) str << " u1=" << nodeAddr(user1p());