forked from github/verilator
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:
parent
10796457d2
commit
9a20a258f5
14
src/V3Ast.h
14
src/V3Ast.h
@ -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(); }
|
||||||
|
@ -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());
|
||||||
|
Loading…
Reference in New Issue
Block a user