From 71b2eeef67e6e790372ef7db28ff66390d344c20 Mon Sep 17 00:00:00 2001 From: John Coiner Date: Thu, 23 Nov 2017 08:21:20 -0500 Subject: [PATCH] Internals: V3GenClk should scan CFunc internals only at the CCall Signed-off-by: Wilson Snyder --- src/V3GenClk.cpp | 30 ++++++++++++++++++++++-------- 1 file changed, 22 insertions(+), 8 deletions(-) diff --git a/src/V3GenClk.cpp b/src/V3GenClk.cpp index f06ef354b..a8c7beaf1 100644 --- a/src/V3GenClk.cpp +++ b/src/V3GenClk.cpp @@ -149,9 +149,10 @@ private: AstUser1InUse m_inuser1; // STATE - AstActive* m_activep; // Inside activate statement - AstNodeAssign* m_assignp; // Inside assigndly statement - AstNodeModule* m_topModp; // Top module + AstActive* m_activep; // Inside activate statement + AstCFunc* m_tracingCallp; // Currently tracing a call to this cfunc + AstNodeAssign* m_assignp; // Inside assigndly statement + AstNodeModule* m_topModp; // Top module // VISITORS virtual void visit(AstTopScope* nodep) { @@ -173,8 +174,20 @@ private: virtual void visit(AstCCall* nodep) { nodep->iterateChildren(*this); // Enter the function and trace it + + m_tracingCallp = nodep->funcp(); nodep->funcp()->accept(*this); } + virtual void visit(AstCFunc* nodep) { + if (m_tracingCallp != nodep) { + // Only consider logic within a CFunc when looking + // at the call to it, and not when scanning whatever + // scope it happens to live beneath. + return; + } + m_tracingCallp = NULL; + nodep->iterateChildren(*this); + } //---- virtual void visit(AstVarRef* nodep) { @@ -213,11 +226,12 @@ private: } public: // CONSTRUCTORS - explicit GenClkReadVisitor(AstNetlist* nodep) { - m_activep = NULL; - m_assignp = NULL; - m_topModp = NULL; - nodep->accept(*this); + explicit GenClkReadVisitor(AstNetlist* nodep) + : m_activep(NULL) + , m_tracingCallp(NULL) + , m_assignp(NULL) + , m_topModp(NULL) { + nodep->accept(*this); } virtual ~GenClkReadVisitor() {} };