mirror of
https://github.com/verilator/verilator.git
synced 2025-04-05 04:02:37 +00:00
[Vpi] Fix missing scopes 2 (#4965)
This commit is contained in:
parent
28718f964a
commit
63fa6accc4
@ -858,13 +858,42 @@ public:
|
|||||||
void dumpJson(std::ostream& str) const override;
|
void dumpJson(std::ostream& str) const override;
|
||||||
// ACCESSORS
|
// ACCESSORS
|
||||||
string name() const override VL_MT_STABLE { return m_name; } // * = Cell name
|
string name() const override VL_MT_STABLE { return m_name; } // * = Cell name
|
||||||
|
bool maybePointedTo() const override { return true; }
|
||||||
string origModName() const { return m_origModName; } // * = modp()->origName() before inlining
|
string origModName() const { return m_origModName; } // * = modp()->origName() before inlining
|
||||||
void name(const string& name) override { m_name = name; }
|
void name(const string& name) override { m_name = name; }
|
||||||
void scopep(AstScope* scp) { m_scopep = scp; }
|
|
||||||
AstScope* scopep() const { return m_scopep; }
|
|
||||||
void timeunit(const VTimescale& flag) { m_timeunit = flag; }
|
void timeunit(const VTimescale& flag) { m_timeunit = flag; }
|
||||||
VTimescale timeunit() const { return m_timeunit; }
|
VTimescale timeunit() const { return m_timeunit; }
|
||||||
};
|
};
|
||||||
|
|
||||||
|
class AstCellInlineScope final : public AstNode {
|
||||||
|
// A particular scoped usage of a Cell Inline
|
||||||
|
// Parents: Scope
|
||||||
|
// Children: none
|
||||||
|
//
|
||||||
|
// @astgen ptr := m_scopep : Optional[AstScope] // Scope variable is underneath
|
||||||
|
// @astgen ptr := m_cellp : Optional[AstCellInline] // Cell ref
|
||||||
|
const string m_origModName; // Original name of module, ignoring name() changes, for LinkDot
|
||||||
|
public:
|
||||||
|
AstCellInlineScope(FileLine* fl, AstScope* scopep, AstCellInline* cellp)
|
||||||
|
: ASTGEN_SUPER_CellInlineScope(fl)
|
||||||
|
, m_scopep{scopep}
|
||||||
|
, m_cellp{cellp} {
|
||||||
|
UASSERT_OBJ(scopep, fl, "Scope must be non-null");
|
||||||
|
UASSERT_OBJ(cellp, fl, "CellInline must be non-null");
|
||||||
|
}
|
||||||
|
ASTGEN_MEMBERS_AstCellInlineScope;
|
||||||
|
void dump(std::ostream& str) const override;
|
||||||
|
void dumpJson(std::ostream& str) const override;
|
||||||
|
// ACCESSORS
|
||||||
|
string name() const override VL_MT_STABLE { return m_cellp->name(); }
|
||||||
|
bool maybePointedTo() const override { return true; }
|
||||||
|
AstScope* scopep() const VL_MT_STABLE { return m_scopep; } // Pointer to scope it's under
|
||||||
|
string origModName() const {
|
||||||
|
return m_cellp->origModName();
|
||||||
|
} // * = modp()->origName() before inlining
|
||||||
|
void scopep(AstScope* nodep) { m_scopep = nodep; }
|
||||||
|
};
|
||||||
|
|
||||||
class AstClassExtends final : public AstNode {
|
class AstClassExtends final : public AstNode {
|
||||||
// class extends class name, or class implements class name
|
// class extends class name, or class implements class name
|
||||||
// Children: List of AstParseRef for packages/classes
|
// Children: List of AstParseRef for packages/classes
|
||||||
@ -1460,6 +1489,7 @@ class AstScope final : public AstNode {
|
|||||||
// Children: NODEBLOCK
|
// Children: NODEBLOCK
|
||||||
// @astgen op1 := varsp : List[AstVarScope]
|
// @astgen op1 := varsp : List[AstVarScope]
|
||||||
// @astgen op2 := blocksp : List[AstNode] // Logic blocks/AstActive/AstCFunc
|
// @astgen op2 := blocksp : List[AstNode] // Logic blocks/AstActive/AstCFunc
|
||||||
|
// @astgen op3 := inlinesp : List[AstCellInlineScope] // Cell Inlines
|
||||||
//
|
//
|
||||||
// Below scope and cell are nullptr if top scope
|
// Below scope and cell are nullptr if top scope
|
||||||
// @astgen ptr := m_aboveScopep : Optional[AstScope] // Scope above this one in the hierarchy
|
// @astgen ptr := m_aboveScopep : Optional[AstScope] // Scope above this one in the hierarchy
|
||||||
|
@ -1503,12 +1503,20 @@ void AstCell::dumpJson(std::ostream& str) const {
|
|||||||
void AstCellInline::dump(std::ostream& str) const {
|
void AstCellInline::dump(std::ostream& str) const {
|
||||||
this->AstNode::dump(str);
|
this->AstNode::dump(str);
|
||||||
str << " -> " << origModName();
|
str << " -> " << origModName();
|
||||||
str << " [scopep=" << nodeAddr(scopep()) << "]";
|
|
||||||
}
|
}
|
||||||
void AstCellInline::dumpJson(std::ostream& str) const {
|
void AstCellInline::dumpJson(std::ostream& str) const {
|
||||||
dumpJsonStrFunc(str, origModName);
|
dumpJsonStrFunc(str, origModName);
|
||||||
dumpJsonGen(str);
|
dumpJsonGen(str);
|
||||||
}
|
}
|
||||||
|
void AstCellInlineScope::dump(std::ostream& str) const {
|
||||||
|
this->AstNode::dump(str);
|
||||||
|
str << " -> " << origModName();
|
||||||
|
str << " [scopep=" << nodeAddr(scopep()) << "]";
|
||||||
|
}
|
||||||
|
void AstCellInlineScope::dumpJson(std::ostream& str) const {
|
||||||
|
dumpJsonStrFunc(str, origModName);
|
||||||
|
dumpJsonGen(str);
|
||||||
|
}
|
||||||
bool AstClass::isCacheableChild(const AstNode* nodep) {
|
bool AstClass::isCacheableChild(const AstNode* nodep) {
|
||||||
return (VN_IS(nodep, Var) || VN_IS(nodep, Constraint) || VN_IS(nodep, EnumItemRef)
|
return (VN_IS(nodep, Var) || VN_IS(nodep, Constraint) || VN_IS(nodep, EnumItemRef)
|
||||||
|| (VN_IS(nodep, NodeFTask) && !VN_AS(nodep, NodeFTask)->isExternProto())
|
|| (VN_IS(nodep, NodeFTask) && !VN_AS(nodep, NodeFTask)->isExternProto())
|
||||||
|
@ -316,7 +316,7 @@ class EmitCSyms final : EmitCBaseVisitorConst {
|
|||||||
iterateChildrenConst(nodep);
|
iterateChildrenConst(nodep);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
void visit(AstCellInline* nodep) override {
|
void visit(AstCellInlineScope* nodep) override {
|
||||||
if (v3Global.opt.vpi()) {
|
if (v3Global.opt.vpi()) {
|
||||||
const string type
|
const string type
|
||||||
= (nodep->origModName() == "__BEGIN__") ? "SCOPE_OTHER" : "SCOPE_MODULE";
|
= (nodep->origModName() == "__BEGIN__") ? "SCOPE_OTHER" : "SCOPE_MODULE";
|
||||||
@ -342,6 +342,7 @@ class EmitCSyms final : EmitCBaseVisitorConst {
|
|||||||
scopeSymString(nodep->name()),
|
scopeSymString(nodep->name()),
|
||||||
ScopeData{nodep, scopeSymString(nodep->name()), name_pretty, timeunit, type});
|
ScopeData{nodep, scopeSymString(nodep->name()), name_pretty, timeunit, type});
|
||||||
}
|
}
|
||||||
|
iterateChildrenConst(nodep);
|
||||||
}
|
}
|
||||||
void visit(AstScopeName* nodep) override {
|
void visit(AstScopeName* nodep) override {
|
||||||
const string name = nodep->scopeSymName();
|
const string name = nodep->scopeSymName();
|
||||||
|
@ -465,10 +465,8 @@ class HasherVisitor final : public VNVisitorConst {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
void visit(AstCellInline* nodep) override {
|
void visit(AstCellInline* nodep) override {
|
||||||
m_hash += hashNodeAndIterate(nodep, HASH_DTYPE, HASH_CHILDREN, [this, nodep]() {
|
m_hash += hashNodeAndIterate(nodep, HASH_DTYPE, HASH_CHILDREN,
|
||||||
m_hash += nodep->name();
|
[this, nodep]() { m_hash += nodep->name(); });
|
||||||
iterateConstNull(nodep->scopep());
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
void visit(AstNodeFTask* nodep) override {
|
void visit(AstNodeFTask* nodep) override {
|
||||||
m_hash += hashNodeAndIterate(nodep, HASH_DTYPE, HASH_CHILDREN, [this, nodep]() { //
|
m_hash += hashNodeAndIterate(nodep, HASH_DTYPE, HASH_CHILDREN, [this, nodep]() { //
|
||||||
|
@ -178,7 +178,9 @@ class ScopeVisitor final : public VNVisitor {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
void visit(AstCellInline* nodep) override { //
|
void visit(AstCellInline* nodep) override { //
|
||||||
nodep->scopep(m_scopep);
|
if (v3Global.opt.vpi()) {
|
||||||
|
m_scopep->addInlinesp(new AstCellInlineScope{nodep->fileline(), m_scopep, nodep});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
void visit(AstActive* nodep) override { // LCOV_EXCL_LINE
|
void visit(AstActive* nodep) override { // LCOV_EXCL_LINE
|
||||||
nodep->v3fatalSrc("Actives now made after scoping");
|
nodep->v3fatalSrc("Actives now made after scoping");
|
||||||
|
@ -1286,6 +1286,10 @@ sub compile {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if ($param{make_pli}) {
|
if ($param{make_pli}) {
|
||||||
|
# if make_pli is a string and not one
|
||||||
|
if ($param{make_pli} ne "1") {
|
||||||
|
$self->{pli_filename} = $param{make_pli};
|
||||||
|
}
|
||||||
$self->oprint("Compile vpi\n") if $self->{verbose};
|
$self->oprint("Compile vpi\n") if $self->{verbose};
|
||||||
my @cmd = ($ENV{CXX}, @{$param{pli_flags}},
|
my @cmd = ($ENV{CXX}, @{$param{pli_flags}},
|
||||||
"-D" . $param{tool_define},
|
"-D" . $param{tool_define},
|
||||||
|
@ -53,7 +53,7 @@
|
|||||||
"modulep": [
|
"modulep": [
|
||||||
{"type":"MODULE","name":"@CONST-POOL@","addr":"(EB)","loc":"a,0:0,0:0","origName":"@CONST-POOL@","level":0,"modPublic":false,"inLibrary":false,"dead":false,"recursiveClone":false,"recursive":false,"timeunit":"NONE","inlinesp": [],
|
{"type":"MODULE","name":"@CONST-POOL@","addr":"(EB)","loc":"a,0:0,0:0","origName":"@CONST-POOL@","level":0,"modPublic":false,"inLibrary":false,"dead":false,"recursiveClone":false,"recursive":false,"timeunit":"NONE","inlinesp": [],
|
||||||
"stmtsp": [
|
"stmtsp": [
|
||||||
{"type":"SCOPE","name":"@CONST-POOL@","addr":"(FB)","loc":"a,0:0,0:0","aboveScopep":"UNLINKED","aboveCellp":"UNLINKED","modp":"(EB)","varsp": [],"blocksp": []}
|
{"type":"SCOPE","name":"@CONST-POOL@","addr":"(FB)","loc":"a,0:0,0:0","aboveScopep":"UNLINKED","aboveCellp":"UNLINKED","modp":"(EB)","varsp": [],"blocksp": [],"inlinesp": []}
|
||||||
],"activesp": []}
|
],"activesp": []}
|
||||||
]}
|
]}
|
||||||
]}
|
]}
|
||||||
|
@ -48,7 +48,7 @@
|
|||||||
"modulep": [
|
"modulep": [
|
||||||
{"type":"MODULE","name":"@CONST-POOL@","addr":"(BB)","loc":"a,0:0,0:0","origName":"@CONST-POOL@","level":0,"modPublic":false,"inLibrary":false,"dead":false,"recursiveClone":false,"recursive":false,"timeunit":"NONE","inlinesp": [],
|
{"type":"MODULE","name":"@CONST-POOL@","addr":"(BB)","loc":"a,0:0,0:0","origName":"@CONST-POOL@","level":0,"modPublic":false,"inLibrary":false,"dead":false,"recursiveClone":false,"recursive":false,"timeunit":"NONE","inlinesp": [],
|
||||||
"stmtsp": [
|
"stmtsp": [
|
||||||
{"type":"SCOPE","name":"@CONST-POOL@","addr":"(CB)","loc":"a,0:0,0:0","aboveScopep":"UNLINKED","aboveCellp":"UNLINKED","modp":"(BB)","varsp": [],"blocksp": []}
|
{"type":"SCOPE","name":"@CONST-POOL@","addr":"(CB)","loc":"a,0:0,0:0","aboveScopep":"UNLINKED","aboveCellp":"UNLINKED","modp":"(BB)","varsp": [],"blocksp": [],"inlinesp": []}
|
||||||
],"activesp": []}
|
],"activesp": []}
|
||||||
]}
|
]}
|
||||||
]}
|
]}
|
||||||
|
@ -13,7 +13,7 @@
|
|||||||
{"type":"CELL","name":"$unit","addr":"(X)","loc":"a,0:0,0:0","origName":"__024unit","recursive":false,"modp":"(E)","pinsp": [],"paramsp": [],"rangep": [],"intfRefsp": []},
|
{"type":"CELL","name":"$unit","addr":"(X)","loc":"a,0:0,0:0","origName":"__024unit","recursive":false,"modp":"(E)","pinsp": [],"paramsp": [],"rangep": [],"intfRefsp": []},
|
||||||
{"type":"TOPSCOPE","name":"","addr":"(H)","loc":"d,11:8,11:9","senTreesp": [],
|
{"type":"TOPSCOPE","name":"","addr":"(H)","loc":"d,11:8,11:9","senTreesp": [],
|
||||||
"scopep": [
|
"scopep": [
|
||||||
{"type":"SCOPE","name":"TOP","addr":"(Y)","loc":"d,11:8,11:9","aboveScopep":"UNLINKED","aboveCellp":"UNLINKED","modp":"(I)","varsp": [],"blocksp": []}
|
{"type":"SCOPE","name":"TOP","addr":"(Y)","loc":"d,11:8,11:9","aboveScopep":"UNLINKED","aboveCellp":"UNLINKED","modp":"(I)","varsp": [],"blocksp": [],"inlinesp": []}
|
||||||
]},
|
]},
|
||||||
{"type":"CFUNC","name":"_eval_static","addr":"(Z)","loc":"a,0:0,0:0","slow":true,"isStatic":false,"dpiExportDispatcher":false,"dpiExportImpl":false,"dpiImportPrototype":false,"dpiImportWrapper":false,"dpiContext":false,"isConstructor":false,"isDestructor":false,"isVirtual":false,"isCoroutine":false,"needProcess":false,"scopep":"(Y)","argsp": [],"initsp": [],
|
{"type":"CFUNC","name":"_eval_static","addr":"(Z)","loc":"a,0:0,0:0","slow":true,"isStatic":false,"dpiExportDispatcher":false,"dpiExportImpl":false,"dpiImportPrototype":false,"dpiImportWrapper":false,"dpiContext":false,"isConstructor":false,"isDestructor":false,"isVirtual":false,"isCoroutine":false,"needProcess":false,"scopep":"(Y)","argsp": [],"initsp": [],
|
||||||
"stmtsp": [
|
"stmtsp": [
|
||||||
@ -2888,7 +2888,7 @@
|
|||||||
]}
|
]}
|
||||||
]}
|
]}
|
||||||
],"attrsp": []},
|
],"attrsp": []},
|
||||||
{"type":"SCOPE","name":"$unit","addr":"(JQB)","loc":"a,0:0,0:0","aboveScopep":"(Y)","aboveCellp":"(X)","modp":"(E)","varsp": [],"blocksp": []},
|
{"type":"SCOPE","name":"$unit","addr":"(JQB)","loc":"a,0:0,0:0","aboveScopep":"(Y)","aboveCellp":"(X)","modp":"(E)","varsp": [],"blocksp": [],"inlinesp": []},
|
||||||
{"type":"CFUNC","name":"_ctor_var_reset","addr":"(KQB)","loc":"a,0:0,0:0","slow":true,"isStatic":false,"dpiExportDispatcher":false,"dpiExportImpl":false,"dpiImportPrototype":false,"dpiImportWrapper":false,"dpiContext":false,"isConstructor":false,"isDestructor":false,"isVirtual":false,"isCoroutine":false,"needProcess":false,"scopep":"UNLINKED","argsp": [],"initsp": [],
|
{"type":"CFUNC","name":"_ctor_var_reset","addr":"(KQB)","loc":"a,0:0,0:0","slow":true,"isStatic":false,"dpiExportDispatcher":false,"dpiExportImpl":false,"dpiImportPrototype":false,"dpiImportWrapper":false,"dpiContext":false,"isConstructor":false,"isDestructor":false,"isVirtual":false,"isCoroutine":false,"needProcess":false,"scopep":"UNLINKED","argsp": [],"initsp": [],
|
||||||
"stmtsp": [
|
"stmtsp": [
|
||||||
{"type":"CRESET","name":"","addr":"(LQB)","loc":"d,17:12,17:16",
|
{"type":"CRESET","name":"","addr":"(LQB)","loc":"d,17:12,17:16",
|
||||||
@ -2992,7 +2992,7 @@
|
|||||||
"modulep": [
|
"modulep": [
|
||||||
{"type":"MODULE","name":"@CONST-POOL@","addr":"(VRB)","loc":"a,0:0,0:0","origName":"@CONST-POOL@","level":0,"modPublic":false,"inLibrary":false,"dead":false,"recursiveClone":false,"recursive":false,"timeunit":"NONE","inlinesp": [],
|
{"type":"MODULE","name":"@CONST-POOL@","addr":"(VRB)","loc":"a,0:0,0:0","origName":"@CONST-POOL@","level":0,"modPublic":false,"inLibrary":false,"dead":false,"recursiveClone":false,"recursive":false,"timeunit":"NONE","inlinesp": [],
|
||||||
"stmtsp": [
|
"stmtsp": [
|
||||||
{"type":"SCOPE","name":"TOP","addr":"(WRB)","loc":"a,0:0,0:0","aboveScopep":"UNLINKED","aboveCellp":"UNLINKED","modp":"(VRB)","varsp": [],"blocksp": []}
|
{"type":"SCOPE","name":"TOP","addr":"(WRB)","loc":"a,0:0,0:0","aboveScopep":"UNLINKED","aboveCellp":"UNLINKED","modp":"(VRB)","varsp": [],"blocksp": [],"inlinesp": []}
|
||||||
],"activesp": []}
|
],"activesp": []}
|
||||||
]}
|
]}
|
||||||
]}
|
]}
|
||||||
|
@ -95,7 +95,7 @@
|
|||||||
"modulep": [
|
"modulep": [
|
||||||
{"type":"MODULE","name":"@CONST-POOL@","addr":"(WB)","loc":"a,0:0,0:0","origName":"@CONST-POOL@","level":0,"modPublic":false,"inLibrary":false,"dead":false,"recursiveClone":false,"recursive":false,"timeunit":"NONE","inlinesp": [],
|
{"type":"MODULE","name":"@CONST-POOL@","addr":"(WB)","loc":"a,0:0,0:0","origName":"@CONST-POOL@","level":0,"modPublic":false,"inLibrary":false,"dead":false,"recursiveClone":false,"recursive":false,"timeunit":"NONE","inlinesp": [],
|
||||||
"stmtsp": [
|
"stmtsp": [
|
||||||
{"type":"SCOPE","name":"@CONST-POOL@","addr":"(XB)","loc":"a,0:0,0:0","aboveScopep":"UNLINKED","aboveCellp":"UNLINKED","modp":"(WB)","varsp": [],"blocksp": []}
|
{"type":"SCOPE","name":"@CONST-POOL@","addr":"(XB)","loc":"a,0:0,0:0","aboveScopep":"UNLINKED","aboveCellp":"UNLINKED","modp":"(WB)","varsp": [],"blocksp": [],"inlinesp": []}
|
||||||
],"activesp": []}
|
],"activesp": []}
|
||||||
]}
|
]}
|
||||||
]}
|
]}
|
||||||
|
@ -133,7 +133,7 @@
|
|||||||
"lhsp": [
|
"lhsp": [
|
||||||
{"type":"VARREF","name":"q","addr":"(AD)","loc":"d,53:13,53:14","dtypep":"(H)","access":"WR","varp":"(G)","varScopep":"(BB)","classOrPackagep":"UNLINKED"}
|
{"type":"VARREF","name":"q","addr":"(AD)","loc":"d,53:13,53:14","dtypep":"(H)","access":"WR","varp":"(G)","varScopep":"(BB)","classOrPackagep":"UNLINKED"}
|
||||||
],"timingControlp": [],"strengthSpecp": []}
|
],"timingControlp": [],"strengthSpecp": []}
|
||||||
]}
|
],"inlinesp": []}
|
||||||
]}
|
]}
|
||||||
],"activesp": []}
|
],"activesp": []}
|
||||||
],"filesp": [],
|
],"filesp": [],
|
||||||
@ -148,7 +148,7 @@
|
|||||||
"modulep": [
|
"modulep": [
|
||||||
{"type":"MODULE","name":"@CONST-POOL@","addr":"(BD)","loc":"a,0:0,0:0","origName":"@CONST-POOL@","level":0,"modPublic":false,"inLibrary":false,"dead":false,"recursiveClone":false,"recursive":false,"timeunit":"NONE","inlinesp": [],
|
{"type":"MODULE","name":"@CONST-POOL@","addr":"(BD)","loc":"a,0:0,0:0","origName":"@CONST-POOL@","level":0,"modPublic":false,"inLibrary":false,"dead":false,"recursiveClone":false,"recursive":false,"timeunit":"NONE","inlinesp": [],
|
||||||
"stmtsp": [
|
"stmtsp": [
|
||||||
{"type":"SCOPE","name":"@CONST-POOL@","addr":"(CD)","loc":"a,0:0,0:0","aboveScopep":"UNLINKED","aboveCellp":"UNLINKED","modp":"(BD)","varsp": [],"blocksp": []}
|
{"type":"SCOPE","name":"@CONST-POOL@","addr":"(CD)","loc":"a,0:0,0:0","aboveScopep":"UNLINKED","aboveCellp":"UNLINKED","modp":"(BD)","varsp": [],"blocksp": [],"inlinesp": []}
|
||||||
],"activesp": []}
|
],"activesp": []}
|
||||||
]}
|
]}
|
||||||
]}
|
]}
|
||||||
|
@ -28,7 +28,7 @@
|
|||||||
"lhsp": [
|
"lhsp": [
|
||||||
{"type":"VARREF","name":"top.f.i_clk","addr":"(T)","loc":"d,7:24,7:29","dtypep":"(H)","access":"WR","varp":"(J)","varScopep":"(N)","classOrPackagep":"UNLINKED"}
|
{"type":"VARREF","name":"top.f.i_clk","addr":"(T)","loc":"d,7:24,7:29","dtypep":"(H)","access":"WR","varp":"(J)","varScopep":"(N)","classOrPackagep":"UNLINKED"}
|
||||||
],"timingControlp": []}
|
],"timingControlp": []}
|
||||||
]}
|
],"inlinesp": []}
|
||||||
]}
|
]}
|
||||||
],"activesp": []}
|
],"activesp": []}
|
||||||
],"filesp": [],
|
],"filesp": [],
|
||||||
@ -41,7 +41,7 @@
|
|||||||
"modulep": [
|
"modulep": [
|
||||||
{"type":"MODULE","name":"@CONST-POOL@","addr":"(U)","loc":"a,0:0,0:0","origName":"@CONST-POOL@","level":0,"modPublic":false,"inLibrary":false,"dead":false,"recursiveClone":false,"recursive":false,"timeunit":"NONE","inlinesp": [],
|
{"type":"MODULE","name":"@CONST-POOL@","addr":"(U)","loc":"a,0:0,0:0","origName":"@CONST-POOL@","level":0,"modPublic":false,"inLibrary":false,"dead":false,"recursiveClone":false,"recursive":false,"timeunit":"NONE","inlinesp": [],
|
||||||
"stmtsp": [
|
"stmtsp": [
|
||||||
{"type":"SCOPE","name":"@CONST-POOL@","addr":"(V)","loc":"a,0:0,0:0","aboveScopep":"UNLINKED","aboveCellp":"UNLINKED","modp":"(U)","varsp": [],"blocksp": []}
|
{"type":"SCOPE","name":"@CONST-POOL@","addr":"(V)","loc":"a,0:0,0:0","aboveScopep":"UNLINKED","aboveCellp":"UNLINKED","modp":"(U)","varsp": [],"blocksp": [],"inlinesp": []}
|
||||||
],"activesp": []}
|
],"activesp": []}
|
||||||
]}
|
]}
|
||||||
]}
|
]}
|
||||||
|
@ -28,7 +28,7 @@
|
|||||||
"lhsp": [
|
"lhsp": [
|
||||||
{"type":"VARREF","name":"top.f.i_clk","addr":"(T)","loc":"d,7:24,7:29","dtypep":"(H)","access":"WR","varp":"(J)","varScopep":"(N)","classOrPackagep":"UNLINKED"}
|
{"type":"VARREF","name":"top.f.i_clk","addr":"(T)","loc":"d,7:24,7:29","dtypep":"(H)","access":"WR","varp":"(J)","varScopep":"(N)","classOrPackagep":"UNLINKED"}
|
||||||
],"timingControlp": []}
|
],"timingControlp": []}
|
||||||
]}
|
],"inlinesp": []}
|
||||||
]}
|
]}
|
||||||
],"activesp": []}
|
],"activesp": []}
|
||||||
],"filesp": [],
|
],"filesp": [],
|
||||||
@ -41,7 +41,7 @@
|
|||||||
"modulep": [
|
"modulep": [
|
||||||
{"type":"MODULE","name":"@CONST-POOL@","addr":"(U)","loc":"a,0:0,0:0","origName":"@CONST-POOL@","level":0,"modPublic":false,"inLibrary":false,"dead":false,"recursiveClone":false,"recursive":false,"timeunit":"NONE","inlinesp": [],
|
{"type":"MODULE","name":"@CONST-POOL@","addr":"(U)","loc":"a,0:0,0:0","origName":"@CONST-POOL@","level":0,"modPublic":false,"inLibrary":false,"dead":false,"recursiveClone":false,"recursive":false,"timeunit":"NONE","inlinesp": [],
|
||||||
"stmtsp": [
|
"stmtsp": [
|
||||||
{"type":"SCOPE","name":"@CONST-POOL@","addr":"(V)","loc":"a,0:0,0:0","aboveScopep":"UNLINKED","aboveCellp":"UNLINKED","modp":"(U)","varsp": [],"blocksp": []}
|
{"type":"SCOPE","name":"@CONST-POOL@","addr":"(V)","loc":"a,0:0,0:0","aboveScopep":"UNLINKED","aboveCellp":"UNLINKED","modp":"(U)","varsp": [],"blocksp": [],"inlinesp": []}
|
||||||
],"activesp": []}
|
],"activesp": []}
|
||||||
]}
|
]}
|
||||||
]}
|
]}
|
||||||
|
@ -288,7 +288,7 @@
|
|||||||
{"type":"VARREF","name":"o_b","addr":"(NF)","loc":"d,25:10,25:13","dtypep":"(K)","access":"WR","varp":"(L)","varScopep":"(U)","classOrPackagep":"UNLINKED"}
|
{"type":"VARREF","name":"o_b","addr":"(NF)","loc":"d,25:10,25:13","dtypep":"(K)","access":"WR","varp":"(L)","varScopep":"(U)","classOrPackagep":"UNLINKED"}
|
||||||
],"timingControlp": []}
|
],"timingControlp": []}
|
||||||
]}
|
]}
|
||||||
]}
|
],"inlinesp": []}
|
||||||
]},
|
]},
|
||||||
{"type":"VAR","name":"__Vfunc_vlvbound_test.foo__0__Vfuncout","addr":"(AB)","loc":"d,15:34,15:37","dtypep":"(K)","origName":"__Vfunc_vlvbound_test__DOT__foo__0__Vfuncout","isSc":false,"isPrimaryIO":false,"direction":"NONE","isConst":false,"isPullup":false,"isPulldown":false,"isUsedClock":false,"isSigPublic":false,"isLatched":false,"isUsedLoopIdx":false,"noReset":false,"attrIsolateAssign":false,"attrFileDescr":false,"isDpiOpenArray":false,"isFuncReturn":false,"isFuncLocal":false,"attrClocker":"UNKNOWN","lifetime":"NONE","varType":"BLOCKTEMP","dtypeName":"logic","isSigUserRdPublic":false,"isSigUserRWPublic":false,"isGParam":false,"isParam":false,"attrScBv":false,"attrSFormat":false,"sensIfacep":"UNLINKED","childDTypep": [],"delayp": [],"valuep": [],"attrsp": []},
|
{"type":"VAR","name":"__Vfunc_vlvbound_test.foo__0__Vfuncout","addr":"(AB)","loc":"d,15:34,15:37","dtypep":"(K)","origName":"__Vfunc_vlvbound_test__DOT__foo__0__Vfuncout","isSc":false,"isPrimaryIO":false,"direction":"NONE","isConst":false,"isPullup":false,"isPulldown":false,"isUsedClock":false,"isSigPublic":false,"isLatched":false,"isUsedLoopIdx":false,"noReset":false,"attrIsolateAssign":false,"attrFileDescr":false,"isDpiOpenArray":false,"isFuncReturn":false,"isFuncLocal":false,"attrClocker":"UNKNOWN","lifetime":"NONE","varType":"BLOCKTEMP","dtypeName":"logic","isSigUserRdPublic":false,"isSigUserRWPublic":false,"isGParam":false,"isParam":false,"attrScBv":false,"attrSFormat":false,"sensIfacep":"UNLINKED","childDTypep": [],"delayp": [],"valuep": [],"attrsp": []},
|
||||||
{"type":"VAR","name":"__Vfunc_vlvbound_test.foo__0__val","addr":"(CB)","loc":"d,15:57,15:60","dtypep":"(H)","origName":"__Vfunc_vlvbound_test__DOT__foo__0__val","isSc":false,"isPrimaryIO":false,"direction":"NONE","isConst":false,"isPullup":false,"isPulldown":false,"isUsedClock":false,"isSigPublic":false,"isLatched":false,"isUsedLoopIdx":false,"noReset":false,"attrIsolateAssign":false,"attrFileDescr":false,"isDpiOpenArray":false,"isFuncReturn":false,"isFuncLocal":false,"attrClocker":"UNKNOWN","lifetime":"NONE","varType":"BLOCKTEMP","dtypeName":"logic","isSigUserRdPublic":false,"isSigUserRWPublic":false,"isGParam":false,"isParam":false,"attrScBv":false,"attrSFormat":false,"sensIfacep":"UNLINKED","childDTypep": [],"delayp": [],"valuep": [],"attrsp": []},
|
{"type":"VAR","name":"__Vfunc_vlvbound_test.foo__0__val","addr":"(CB)","loc":"d,15:57,15:60","dtypep":"(H)","origName":"__Vfunc_vlvbound_test__DOT__foo__0__val","isSc":false,"isPrimaryIO":false,"direction":"NONE","isConst":false,"isPullup":false,"isPulldown":false,"isUsedClock":false,"isSigPublic":false,"isLatched":false,"isUsedLoopIdx":false,"noReset":false,"attrIsolateAssign":false,"attrFileDescr":false,"isDpiOpenArray":false,"isFuncReturn":false,"isFuncLocal":false,"attrClocker":"UNKNOWN","lifetime":"NONE","varType":"BLOCKTEMP","dtypeName":"logic","isSigUserRdPublic":false,"isSigUserRWPublic":false,"isGParam":false,"isParam":false,"attrScBv":false,"attrSFormat":false,"sensIfacep":"UNLINKED","childDTypep": [],"delayp": [],"valuep": [],"attrsp": []},
|
||||||
@ -317,7 +317,7 @@
|
|||||||
"modulep": [
|
"modulep": [
|
||||||
{"type":"MODULE","name":"@CONST-POOL@","addr":"(OF)","loc":"a,0:0,0:0","origName":"@CONST-POOL@","level":0,"modPublic":false,"inLibrary":false,"dead":false,"recursiveClone":false,"recursive":false,"timeunit":"NONE","inlinesp": [],
|
{"type":"MODULE","name":"@CONST-POOL@","addr":"(OF)","loc":"a,0:0,0:0","origName":"@CONST-POOL@","level":0,"modPublic":false,"inLibrary":false,"dead":false,"recursiveClone":false,"recursive":false,"timeunit":"NONE","inlinesp": [],
|
||||||
"stmtsp": [
|
"stmtsp": [
|
||||||
{"type":"SCOPE","name":"@CONST-POOL@","addr":"(PF)","loc":"a,0:0,0:0","aboveScopep":"UNLINKED","aboveCellp":"UNLINKED","modp":"(OF)","varsp": [],"blocksp": []}
|
{"type":"SCOPE","name":"@CONST-POOL@","addr":"(PF)","loc":"a,0:0,0:0","aboveScopep":"UNLINKED","aboveCellp":"UNLINKED","modp":"(OF)","varsp": [],"blocksp": [],"inlinesp": []}
|
||||||
],"activesp": []}
|
],"activesp": []}
|
||||||
]}
|
]}
|
||||||
]}
|
]}
|
||||||
|
@ -14,7 +14,7 @@
|
|||||||
"modulep": [
|
"modulep": [
|
||||||
{"type":"MODULE","name":"@CONST-POOL@","addr":"(H)","loc":"a,0:0,0:0","origName":"@CONST-POOL@","level":0,"modPublic":false,"inLibrary":false,"dead":false,"recursiveClone":false,"recursive":false,"timeunit":"NONE","inlinesp": [],
|
{"type":"MODULE","name":"@CONST-POOL@","addr":"(H)","loc":"a,0:0,0:0","origName":"@CONST-POOL@","level":0,"modPublic":false,"inLibrary":false,"dead":false,"recursiveClone":false,"recursive":false,"timeunit":"NONE","inlinesp": [],
|
||||||
"stmtsp": [
|
"stmtsp": [
|
||||||
{"type":"SCOPE","name":"@CONST-POOL@","addr":"(I)","loc":"a,0:0,0:0","aboveScopep":"UNLINKED","aboveCellp":"UNLINKED","modp":"(H)","varsp": [],"blocksp": []}
|
{"type":"SCOPE","name":"@CONST-POOL@","addr":"(I)","loc":"a,0:0,0:0","aboveScopep":"UNLINKED","aboveCellp":"UNLINKED","modp":"(H)","varsp": [],"blocksp": [],"inlinesp": []}
|
||||||
],"activesp": []}
|
],"activesp": []}
|
||||||
]}
|
]}
|
||||||
]}
|
]}
|
||||||
|
@ -93,7 +93,7 @@
|
|||||||
"modulep": [
|
"modulep": [
|
||||||
{"type":"MODULE","name":"@CONST-POOL@","addr":"(AC)","loc":"a,0:0,0:0","origName":"@CONST-POOL@","level":0,"modPublic":false,"inLibrary":false,"dead":false,"recursiveClone":false,"recursive":false,"timeunit":"NONE","inlinesp": [],
|
{"type":"MODULE","name":"@CONST-POOL@","addr":"(AC)","loc":"a,0:0,0:0","origName":"@CONST-POOL@","level":0,"modPublic":false,"inLibrary":false,"dead":false,"recursiveClone":false,"recursive":false,"timeunit":"NONE","inlinesp": [],
|
||||||
"stmtsp": [
|
"stmtsp": [
|
||||||
{"type":"SCOPE","name":"@CONST-POOL@","addr":"(BC)","loc":"a,0:0,0:0","aboveScopep":"UNLINKED","aboveCellp":"UNLINKED","modp":"(AC)","varsp": [],"blocksp": []}
|
{"type":"SCOPE","name":"@CONST-POOL@","addr":"(BC)","loc":"a,0:0,0:0","aboveScopep":"UNLINKED","aboveCellp":"UNLINKED","modp":"(AC)","varsp": [],"blocksp": [],"inlinesp": []}
|
||||||
],"activesp": []}
|
],"activesp": []}
|
||||||
]}
|
]}
|
||||||
]}
|
]}
|
||||||
|
@ -99,7 +99,7 @@
|
|||||||
"modulep": [
|
"modulep": [
|
||||||
{"type":"MODULE","name":"@CONST-POOL@","addr":"(AC)","loc":"a,0:0,0:0","origName":"@CONST-POOL@","level":0,"modPublic":false,"inLibrary":false,"dead":false,"recursiveClone":false,"recursive":false,"timeunit":"NONE","inlinesp": [],
|
{"type":"MODULE","name":"@CONST-POOL@","addr":"(AC)","loc":"a,0:0,0:0","origName":"@CONST-POOL@","level":0,"modPublic":false,"inLibrary":false,"dead":false,"recursiveClone":false,"recursive":false,"timeunit":"NONE","inlinesp": [],
|
||||||
"stmtsp": [
|
"stmtsp": [
|
||||||
{"type":"SCOPE","name":"@CONST-POOL@","addr":"(BC)","loc":"a,0:0,0:0","aboveScopep":"UNLINKED","aboveCellp":"UNLINKED","modp":"(AC)","varsp": [],"blocksp": []}
|
{"type":"SCOPE","name":"@CONST-POOL@","addr":"(BC)","loc":"a,0:0,0:0","aboveScopep":"UNLINKED","aboveCellp":"UNLINKED","modp":"(AC)","varsp": [],"blocksp": [],"inlinesp": []}
|
||||||
],"activesp": []}
|
],"activesp": []}
|
||||||
]}
|
]}
|
||||||
]}
|
]}
|
||||||
|
20
test_regress/t/t_vpi_dump_missing_scopes.iv.out
Normal file
20
test_regress/t/t_vpi_dump_missing_scopes.iv.out
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
t (vpiModule) t
|
||||||
|
vpiInternalScope:
|
||||||
|
t.top_wrap_1 (vpiModule) t.top_wrap_1
|
||||||
|
vpiInternalScope:
|
||||||
|
t.top_wrap_1.gen_loop[0] (vpiGenScope) t.top_wrap_1.gen_loop[0]
|
||||||
|
vpiParameter:
|
||||||
|
t.top_wrap_1.gen_loop[0].i (vpiParameter) t.top_wrap_1.gen_loop[0].i
|
||||||
|
vpiConstType=vpiBinaryConst
|
||||||
|
vpiInternalScope:
|
||||||
|
t.top_wrap_1.gen_loop[0].after_gen_loop (vpiModule) t.top_wrap_1.gen_loop[0].after_gen_loop
|
||||||
|
t.top_wrap_2 (vpiModule) t.top_wrap_2
|
||||||
|
vpiInternalScope:
|
||||||
|
t.top_wrap_2.gen_loop[0] (vpiGenScope) t.top_wrap_2.gen_loop[0]
|
||||||
|
vpiParameter:
|
||||||
|
t.top_wrap_2.gen_loop[0].i (vpiParameter) t.top_wrap_2.gen_loop[0].i
|
||||||
|
vpiConstType=vpiBinaryConst
|
||||||
|
vpiInternalScope:
|
||||||
|
t.top_wrap_2.gen_loop[0].after_gen_loop (vpiModule) t.top_wrap_2.gen_loop[0].after_gen_loop
|
||||||
|
*-* All Finished *-*
|
||||||
|
t/t_vpi_dump_missing_scopes.v:21: $finish called at 0 (1s)
|
29
test_regress/t/t_vpi_dump_missing_scopes.out
Normal file
29
test_regress/t/t_vpi_dump_missing_scopes.out
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
t (vpiModule) t
|
||||||
|
vpiReg:
|
||||||
|
vpiParameter:
|
||||||
|
vpiInternalScope:
|
||||||
|
top_wrap_1 (vpiModule) t.top_wrap_1
|
||||||
|
vpiReg:
|
||||||
|
vpiParameter:
|
||||||
|
vpiInternalScope:
|
||||||
|
gen_loop[0] (vpiGenScope) t.top_wrap_1.gen_loop[0]
|
||||||
|
vpiReg:
|
||||||
|
vpiParameter:
|
||||||
|
vpiInternalScope:
|
||||||
|
after_gen_loop (vpiModule) t.top_wrap_1.gen_loop[0].after_gen_loop
|
||||||
|
vpiReg:
|
||||||
|
subsig1 (vpiReg) t.top_wrap_1.gen_loop[0].after_gen_loop.subsig1
|
||||||
|
vpiParameter:
|
||||||
|
top_wrap_2 (vpiModule) t.top_wrap_2
|
||||||
|
vpiReg:
|
||||||
|
vpiParameter:
|
||||||
|
vpiInternalScope:
|
||||||
|
gen_loop[0] (vpiGenScope) t.top_wrap_2.gen_loop[0]
|
||||||
|
vpiReg:
|
||||||
|
vpiParameter:
|
||||||
|
vpiInternalScope:
|
||||||
|
after_gen_loop (vpiModule) t.top_wrap_2.gen_loop[0].after_gen_loop
|
||||||
|
vpiReg:
|
||||||
|
subsig1 (vpiReg) t.top_wrap_2.gen_loop[0].after_gen_loop.subsig1
|
||||||
|
vpiParameter:
|
||||||
|
*-* All Finished *-*
|
34
test_regress/t/t_vpi_dump_missing_scopes.pl
Executable file
34
test_regress/t/t_vpi_dump_missing_scopes.pl
Executable file
@ -0,0 +1,34 @@
|
|||||||
|
#!/usr/bin/env perl
|
||||||
|
if (!$::Driver) { use FindBin; exec("$FindBin::Bin/bootstrap.pl", @ARGV, $0); die; }
|
||||||
|
# DESCRIPTION: Verilator: Verilog Test driver/expect definition
|
||||||
|
#
|
||||||
|
# Copyright 2024 by Wilson Snyder. This program is free software; you
|
||||||
|
# can redistribute it and/or modify it under the terms of either the GNU
|
||||||
|
# Lesser General Public License Version 3 or the Perl Artistic License
|
||||||
|
# Version 2.0.
|
||||||
|
# SPDX-License-Identifier: LGPL-3.0-only OR Artistic-2.0
|
||||||
|
|
||||||
|
scenarios(simulator => 1);
|
||||||
|
|
||||||
|
skip("Known compiler limitation")
|
||||||
|
if $Self->cxx_version =~ /\(GCC\) 4.4/;
|
||||||
|
|
||||||
|
compile(
|
||||||
|
make_top_shell => 0,
|
||||||
|
make_main => 0,
|
||||||
|
make_pli => "t_vpi_dump.cpp",
|
||||||
|
iv_flags2 => ["-g2005-sv"],
|
||||||
|
verilator_flags2 => ["--exe --vpi --public-flat-rw --no-l2name $Self->{t_dir}/t_vpi_dump.cpp $Self->{t_dir}/TestVpiMain.cpp"],
|
||||||
|
make_flags => 'CPPFLAGS_ADD=-DVL_NO_LEGACY',
|
||||||
|
);
|
||||||
|
|
||||||
|
execute(
|
||||||
|
use_libvpi => 1,
|
||||||
|
check_finished => 1,
|
||||||
|
expect_filename => $Self->{golden_filename},
|
||||||
|
xrun_run_expect_filename => ($Self->{golden_filename} =~ s/\.out$/.xrun.out/r),
|
||||||
|
iv_run_expect_filename => ($Self->{golden_filename} =~ s/\.out$/.iv.out/r),
|
||||||
|
);
|
||||||
|
|
||||||
|
ok(1);
|
||||||
|
1;
|
46
test_regress/t/t_vpi_dump_missing_scopes.v
Normal file
46
test_regress/t/t_vpi_dump_missing_scopes.v
Normal file
@ -0,0 +1,46 @@
|
|||||||
|
// DESCRIPTION: Verilator: Verilog Test module
|
||||||
|
//
|
||||||
|
// Copyright 2010 by Wilson Snyder. This program is free software; you can
|
||||||
|
// redistribute it and/or modify it under the terms of either the GNU
|
||||||
|
// Lesser General Public License Version 3 or the Perl Artistic License
|
||||||
|
// Version 2.0.
|
||||||
|
// SPDX-License-Identifier: LGPL-3.0-only OR Artistic-2.0
|
||||||
|
|
||||||
|
|
||||||
|
// using public_on causes one to be AstCellInline, and that one has correct scope
|
||||||
|
// without this, both are AstCellInline, and both are wrong
|
||||||
|
|
||||||
|
/* verilator public_on */
|
||||||
|
|
||||||
|
module t ( /*AUTOARG*/
|
||||||
|
);
|
||||||
|
|
||||||
|
|
||||||
|
initial begin
|
||||||
|
$write("*-* All Finished *-*\n");
|
||||||
|
$finish();
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
gen_wrapper top_wrap_1 ();
|
||||||
|
gen_wrapper top_wrap_2 ();
|
||||||
|
|
||||||
|
endmodule : t
|
||||||
|
|
||||||
|
module sub;
|
||||||
|
reg subsig1;
|
||||||
|
endmodule : sub
|
||||||
|
|
||||||
|
|
||||||
|
module gen_wrapper;
|
||||||
|
genvar i;
|
||||||
|
generate
|
||||||
|
for (i = 0; i < 1; i++) begin : gen_loop
|
||||||
|
|
||||||
|
// This fixes the scope
|
||||||
|
// localparam int x = 2;
|
||||||
|
|
||||||
|
sub after_gen_loop ();
|
||||||
|
end
|
||||||
|
endgenerate
|
||||||
|
endmodule
|
Loading…
Reference in New Issue
Block a user