From ebe8f554c6f04533a88f7482c63f5a1d42ef2449 Mon Sep 17 00:00:00 2001 From: Wilson Snyder Date: Wed, 16 Dec 2009 21:28:35 -0500 Subject: [PATCH] Fix dpiSetScope to really set the scope. --- include/verilated.h | 2 +- src/V3Ast.h | 2 +- src/V3AstNodes.h | 8 +++++--- 3 files changed, 7 insertions(+), 5 deletions(-) diff --git a/include/verilated.h b/include/verilated.h index a1e8d8f4d..dc8d85cbe 100644 --- a/include/verilated.h +++ b/include/verilated.h @@ -201,7 +201,7 @@ public: static const char* catName(const char* n1, const char* n2); // Returns new'ed data // Internal: Get and set DPI context static const VerilatedScope* dpiScope() { return t_dpiScopep; } - static void dpiScope(const VerilatedScope* scopep) { scopep=t_dpiScopep; } + static void dpiScope(const VerilatedScope* scopep) { t_dpiScopep=scopep; } static void dpiContext(const VerilatedScope* scopep, const char* filenamep, int lineno) { t_dpiScopep=scopep; t_dpiFilename=filenamep; t_dpiLineno=lineno; } static void dpiClearContext() { t_dpiScopep = NULL; } diff --git a/src/V3Ast.h b/src/V3Ast.h index c1552f6fa..e342b3f8a 100644 --- a/src/V3Ast.h +++ b/src/V3Ast.h @@ -228,8 +228,8 @@ public: static const char* names[] = { "unsigned char", "char", "void*", "int", "int", "svLogic", "long long", "double", "double", "short int", "float", "long long", - "dpiScope", "const char*", "char*", + "dpiScope", "const char*", "" }; return names[m_e]; diff --git a/src/V3AstNodes.h b/src/V3AstNodes.h index 6c6aea34b..684c5ff4f 100644 --- a/src/V3AstNodes.h +++ b/src/V3AstNodes.h @@ -2330,7 +2330,7 @@ struct AstFGetC : public AstNodeUniop { ASTNODE_NODE_FUNCS(FGetC, FGETC) virtual void numberOperate(V3Number& out, const V3Number& lhs) { V3ERROR_NA; } virtual string emitVerilog() { return "%k$fgetc(%l)"; } - // Non-existant filehandle returns EOF + // Non-existent filehandle returns EOF virtual string emitC() { return "(%li ? fgetc(VL_CVT_Q_FP(%li)) : -1)"; } virtual bool cleanOut() {return false;} virtual bool cleanLhs() {return true;} virtual bool sizeMattersLhs() {return false;} @@ -3267,7 +3267,6 @@ public: if (setwidth) { width(setwidth,setwidth); } } ASTNODE_NODE_FUNCS(CMath, CMATH) - AstNode* bodysp() const { return op1p()->castNode(); } // op1= expressions to print virtual bool isGateOptimizable() const { return false; } virtual bool isPredictOptimizable() const { return false; } virtual bool cleanOut() { return m_cleanOut; } @@ -3275,6 +3274,8 @@ public: virtual string emitC() { V3ERROR_NA; return ""; } virtual V3Hash sameHash() const { return V3Hash(); } virtual bool same(AstNode* samep) const { return true; } + void addBodysp(AstNode* nodep) { addNOp1p(nodep); } + AstNode* bodysp() const { return op1p()->castNode(); } // op1= expressions to print }; @@ -3289,11 +3290,12 @@ struct AstCStmt : public AstNodeStmt { addNOp1p(new AstText(fl, textStmt, true)); } ASTNODE_NODE_FUNCS(CStmt, CSTMT) - AstNode* bodysp() const { return op1p()->castNode(); } // op1= expressions to print virtual bool isGateOptimizable() const { return false; } virtual bool isPredictOptimizable() const { return false; } virtual V3Hash sameHash() const { return V3Hash(); } virtual bool same(AstNode* samep) const { return true; } + void addBodysp(AstNode* nodep) { addNOp1p(nodep); } + AstNode* bodysp() const { return op1p()->castNode(); } // op1= expressions to print }; //######################################################################