diff --git a/include/verilated_trace_imp.h b/include/verilated_trace_imp.h index f44fab7091..34e0b3ea26 100644 --- a/include/verilated_trace_imp.h +++ b/include/verilated_trace_imp.h @@ -64,9 +64,9 @@ static std::string doubleToTimescale(double value) VL_PURE { const char* suffixp = "s"; // clang-format off if (value >= 1e0) { suffixp = "s"; value *= 1e0; } - else if (value >= 1e-3 ) { suffixp = "ms"; value *= 1e3; } - else if (value >= 1e-6 ) { suffixp = "us"; value *= 1e6; } - else if (value >= 1e-9 ) { suffixp = "ns"; value *= 1e9; } + else if (value >= 1e-3) { suffixp = "ms"; value *= 1e3; } + else if (value >= 1e-6) { suffixp = "us"; value *= 1e6; } + else if (value >= 1e-9) { suffixp = "ns"; value *= 1e9; } else if (value >= 1e-12) { suffixp = "ps"; value *= 1e12; } else if (value >= 1e-15) { suffixp = "fs"; value *= 1e15; } else if (value >= 1e-18) { suffixp = "as"; value *= 1e18; } diff --git a/src/V3AstNodes.cpp b/src/V3AstNodes.cpp index aa100866c0..93c7892dd4 100644 --- a/src/V3AstNodes.cpp +++ b/src/V3AstNodes.cpp @@ -1986,7 +1986,7 @@ void AstPackageExport::dump(std::ostream& str) const { this->AstNode::dump(str); str << " -> " << packagep(); } -const char* AstPackageExport ::broken() const { +const char* AstPackageExport::broken() const { BROKEN_RTN(!m_packagep || !m_packagep->brokeExists()); return nullptr; } diff --git a/src/V3Dead.cpp b/src/V3Dead.cpp index 768887b5fc..4cfff2069d 100644 --- a/src/V3Dead.cpp +++ b/src/V3Dead.cpp @@ -79,6 +79,11 @@ class DeadVisitor final : public VNVisitor { // METHODS + void deleting(AstNode* nodep) { + UINFO(9, " deleting " << nodep << endl); + VL_DO_DANGLING(pushDeletep(nodep->unlinkFrBack()), nodep); + } + void checkAll(AstNode* nodep) { if (nodep != nodep->dtypep()) { // NodeDTypes reference themselves if (AstNode* const subnodep = nodep->dtypep()) subnodep->user1Inc(); @@ -239,7 +244,7 @@ class DeadVisitor final : public VNVisitor { iterateChildren(nodep); if (m_elimCells) { if (!nodep->varsp()) { - VL_DO_DANGLING(pushDeletep(nodep->unlinkFrBack()), nodep); + deleting(nodep); return; } } @@ -316,7 +321,7 @@ class DeadVisitor final : public VNVisitor { void deadCheckTypedefs() { for (AstTypedef* typedefp : m_typedefsp) { if (shouldDeleteTypedef(typedefp)) { - VL_DO_DANGLING(pushDeletep(typedefp->unlinkFrBack()), typedefp); + deleting(typedefp); continue; } checkAll(typedefp); @@ -349,7 +354,7 @@ class DeadVisitor final : public VNVisitor { cellp->modp()->user1Inc(-1); }); } - VL_DO_DANGLING(modp->unlinkFrBack()->deleteTree(), modp); + deleting(modp); retry = true; } } @@ -373,7 +378,7 @@ class DeadVisitor final : public VNVisitor { UINFO(4, " Dead AstScope " << scp << endl); scp->aboveScopep()->user1Inc(-1); if (scp->dtypep()) scp->dtypep()->user1Inc(-1); - VL_DO_DANGLING(scp->unlinkFrBack()->deleteTree(), scp); + deleting(scp); *it = nullptr; retry = true; } @@ -385,7 +390,7 @@ class DeadVisitor final : public VNVisitor { for (AstCell* cellp : m_cellsp) { if (cellp->user1() == 0 && !cellp->modp()->stmtsp()) { cellp->modp()->user1Inc(-1); - VL_DO_DANGLING(cellp->unlinkFrBack()->deleteTree(), cellp); + deleting(cellp); } } } @@ -397,7 +402,7 @@ class DeadVisitor final : public VNVisitor { if (nodep->user1() == 0) { if (nodep->extendsp()) nodep->extendsp()->user1Inc(-1); if (nodep->classOrPackagep()) nodep->classOrPackagep()->user1Inc(-1); - VL_DO_DANGLING(pushDeletep(nodep->unlinkFrBack()), nodep); + deleting(nodep); itr = nullptr; retry = true; } @@ -417,11 +422,11 @@ class DeadVisitor final : public VNVisitor { AstNodeAssign* const assp = itr->second; UINFO(4, " Dead assign " << assp << endl); assp->dtypep()->user1Inc(-1); - VL_DO_DANGLING(assp->unlinkFrBack()->deleteTree(), assp); + deleting(assp); } if (vscp->scopep()) vscp->scopep()->user1Inc(-1); vscp->dtypep()->user1Inc(-1); - VL_DO_DANGLING(vscp->unlinkFrBack()->deleteTree(), vscp); + deleting(vscp); } } for (bool retry = true; retry;) { @@ -432,7 +437,7 @@ class DeadVisitor final : public VNVisitor { if (varp->user1() == 0) { UINFO(4, " Dead " << varp << endl); if (varp->dtypep()) varp->dtypep()->user1Inc(-1); - VL_DO_DANGLING(varp->unlinkFrBack()->deleteTree(), varp); + deleting(varp); *it = nullptr; retry = true; } @@ -440,11 +445,11 @@ class DeadVisitor final : public VNVisitor { } for (std::vector::iterator it = m_dtypesp.begin(); it != m_dtypesp.end(); ++it) { if ((*it)->user1() == 0) { - const AstNodeUOrStructDType* classp; // It's possible that there if a reference to each individual member, but // not to the dtype itself. Check and don't remove the parent dtype if // members are still alive. - if ((classp = VN_CAST((*it), NodeUOrStructDType))) { + if (const AstNodeUOrStructDType* const classp + = VN_CAST((*it), NodeUOrStructDType)) { bool cont = true; for (AstMemberDType* memberp = classp->membersp(); memberp; memberp = VN_AS(memberp->nextp(), MemberDType)) { @@ -455,7 +460,7 @@ class DeadVisitor final : public VNVisitor { } if (!cont) continue; } - VL_DO_DANGLING((*it)->unlinkFrBack()->deleteTree(), *it); + deleting(*it); } } } diff --git a/src/V3Graph.cpp b/src/V3Graph.cpp index f77f1d056f..3014ab05d4 100644 --- a/src/V3Graph.cpp +++ b/src/V3Graph.cpp @@ -294,6 +294,12 @@ void V3Graph::dumpEdge(std::ostream& os, const V3GraphVertex* vertexp, os << '\n'; } } +void V3Graph::dumpEdges(std::ostream& os, const V3GraphVertex* vertexp) const { + for (const V3GraphEdge* edgep = vertexp->inBeginp(); edgep; edgep = edgep->inNextp()) + dumpEdge(os, vertexp, edgep); + for (const V3GraphEdge* edgep = vertexp->outBeginp(); edgep; edgep = edgep->outNextp()) + dumpEdge(os, vertexp, edgep); +} void V3Graph::dumpDotFilePrefixed(const string& nameComment, bool colorAsSubgraph) const { dumpDotFile(v3Global.debugFilename(nameComment) + ".dot", colorAsSubgraph); diff --git a/src/V3Graph.h b/src/V3Graph.h index c2973cae7d..aedb60afa5 100644 --- a/src/V3Graph.h +++ b/src/V3Graph.h @@ -180,6 +180,7 @@ class V3Graph VL_NOT_FINAL { bool colorAsSubgraph = false) const VL_MT_DISABLED; void dumpDotFilePrefixedAlways(const string& nameComment, bool colorAsSubgraph = false) const VL_MT_DISABLED; + void dumpEdges(std::ostream& os, const V3GraphVertex* vertexp) const VL_MT_DISABLED; static void selfTest() VL_MT_DISABLED; // CALLBACKS diff --git a/src/V3GraphTest.cpp b/src/V3GraphTest.cpp index 1635bfc6a3..769da38004 100644 --- a/src/V3GraphTest.cpp +++ b/src/V3GraphTest.cpp @@ -149,22 +149,22 @@ class V3GraphTestVars final : public V3GraphTest { public: string name() override { return "vars"; } void runTest() override { - V3Graph* gp = &m_graph; + V3Graph* const gp = &m_graph; - V3GraphTestVertex* clk = new V3GraphTestVarVertex{gp, "$clk"}; + V3GraphTestVertex* const clk = new V3GraphTestVarVertex{gp, "$clk"}; - V3GraphTestVertex* a = new V3GraphTestVarVertex{gp, "$a"}; - V3GraphTestVertex* a_dly = new V3GraphTestVarVertex{gp, "$a_dly"}; - V3GraphTestVertex* a_dlyblk = new V3GraphTestVarVertex{gp, "$a_dlyblk"}; - V3GraphTestVertex* b = new V3GraphTestVarVertex{gp, "$b"}; - V3GraphTestVertex* b_dly = new V3GraphTestVarVertex{gp, "$b_dly"}; - V3GraphTestVertex* b_dlyblk = new V3GraphTestVarVertex{gp, "$b_dlyblk"}; - V3GraphTestVertex* c = new V3GraphTestVarVertex{gp, "$c"}; - V3GraphTestVertex* i = new V3GraphTestVarVertex{gp, "$i"}; + V3GraphTestVertex* const a = new V3GraphTestVarVertex{gp, "$a"}; + V3GraphTestVertex* const a_dly = new V3GraphTestVarVertex{gp, "$a_dly"}; + V3GraphTestVertex* const a_dlyblk = new V3GraphTestVarVertex{gp, "$a_dlyblk"}; + V3GraphTestVertex* const b = new V3GraphTestVarVertex{gp, "$b"}; + V3GraphTestVertex* const b_dly = new V3GraphTestVarVertex{gp, "$b_dly"}; + V3GraphTestVertex* const b_dlyblk = new V3GraphTestVarVertex{gp, "$b_dlyblk"}; + V3GraphTestVertex* const c = new V3GraphTestVarVertex{gp, "$c"}; + V3GraphTestVertex* const i = new V3GraphTestVarVertex{gp, "$i"}; - V3GraphTestVertex* ap = new V3GraphTestVarVertex{gp, "$a_pre"}; - V3GraphTestVertex* bp = new V3GraphTestVarVertex{gp, "$b_pre"}; - V3GraphTestVertex* cp = new V3GraphTestVarVertex{gp, "$c_pre"}; + V3GraphTestVertex* const ap = new V3GraphTestVarVertex{gp, "$a_pre"}; + V3GraphTestVertex* const bp = new V3GraphTestVarVertex{gp, "$b_pre"}; + V3GraphTestVertex* const cp = new V3GraphTestVarVertex{gp, "$c_pre"}; V3GraphTestVertex* n; @@ -185,7 +185,7 @@ class V3GraphTestVars final : public V3GraphTest { new V3GraphEdge{gp, n, i, 2}; } - V3GraphTestVertex* posedge = n = new V3GraphTestVertex{gp, "*posedge clk*"}; + V3GraphTestVertex* const posedge = n = new V3GraphTestVertex{gp, "*posedge clk*"}; { new V3GraphEdge{gp, clk, n, 2}; } // AssignPre's VarRefs on LHS: generate special BLK @@ -258,6 +258,9 @@ class V3GraphTestVars final : public V3GraphTest { gp->acyclic(&V3GraphEdge::followAlwaysTrue); gp->order(); + // Test debug function + gp->dumpEdges(std::cout, ap); + dumpSelf(); } }; diff --git a/src/V3Order.cpp b/src/V3Order.cpp index 7b59511fce..0fa76f7b05 100644 --- a/src/V3Order.cpp +++ b/src/V3Order.cpp @@ -1414,7 +1414,7 @@ void OrderProcess::process(bool multiThreaded) { // edges) will have its own color, and corresponds to a loop in the // original graph. However the new graph will be acyclic (the removed // edges are actually still there, just with weight 0). - UINFO(2, " Acyclic & Order...\n"); + UINFO(2, " Acyclic and Order...\n"); m_graph.acyclic(&V3GraphEdge::followAlwaysTrue); if (dumpGraphLevel()) m_graph.dumpDotFilePrefixed(m_tag + "_orderg_acyc");