Fix interface inside generate, bug998.

This commit is contained in:
Wilson Snyder 2015-11-14 09:06:09 -05:00
parent 9254443cd4
commit 52ae451f5c
4 changed files with 70 additions and 1 deletions

View File

@ -15,6 +15,8 @@ indicates the contributor was also the author of the fix; Thanks!
**** Fix constant function assigned to packed structs, bug997. [Johan Bjork] **** Fix constant function assigned to packed structs, bug997. [Johan Bjork]
**** Fix interface inside generate, bug998. [Johan Bjork]
**** Fix $signed casts under generates, bug999. [Clifford Wolf] **** Fix $signed casts under generates, bug999. [Clifford Wolf]

View File

@ -56,7 +56,7 @@ public:
m_anyFuncInBegin = false; m_anyFuncInBegin = false;
} }
~BeginState() {} ~BeginState() {}
void userMarkChanged(AstNodeFTask* nodep) { void userMarkChanged(AstNode* nodep) {
nodep->user1(true); nodep->user1(true);
m_anyFuncInBegin = true; m_anyFuncInBegin = true;
} }
@ -166,6 +166,7 @@ private:
if (m_unnamedScope != "") { if (m_unnamedScope != "") {
// Rename it // Rename it
nodep->name(m_unnamedScope+"__DOT__"+nodep->name()); nodep->name(m_unnamedScope+"__DOT__"+nodep->name());
m_statep->userMarkChanged(nodep);
// Move to module // Move to module
nodep->unlinkFrBack(); nodep->unlinkFrBack();
if (m_ftaskp) m_ftaskp->addStmtsp(nodep); // Begins under funcs just move into the func if (m_ftaskp) m_ftaskp->addStmtsp(nodep); // Begins under funcs just move into the func
@ -175,6 +176,7 @@ private:
virtual void visit(AstCell* nodep, AstNUser*) { virtual void visit(AstCell* nodep, AstNUser*) {
UINFO(8," CELL "<<nodep<<endl); UINFO(8," CELL "<<nodep<<endl);
if (m_namedScope != "") { if (m_namedScope != "") {
m_statep->userMarkChanged(nodep);
// Rename it // Rename it
nodep->name(m_namedScope+"__DOT__"+nodep->name()); nodep->name(m_namedScope+"__DOT__"+nodep->name());
UINFO(8," rename to "<<nodep->name()<<endl); UINFO(8," rename to "<<nodep->name()<<endl);
@ -182,6 +184,7 @@ private:
nodep->unlinkFrBack(); nodep->unlinkFrBack();
m_modp->addStmtp(nodep); m_modp->addStmtp(nodep);
} }
nodep->iterateChildren(*this);
} }
virtual void visit(AstScopeName* nodep, AstNUser*) { virtual void visit(AstScopeName* nodep, AstNUser*) {
// If there's a %m in the display text, we add a special node that will contain the name() // If there's a %m in the display text, we add a special node that will contain the name()
@ -249,6 +252,21 @@ private:
} }
nodep->iterateChildren(*this); nodep->iterateChildren(*this);
} }
virtual void visit(AstVarRef* nodep, AstNUser*) {
if (nodep->varp()->user1()) { // It was converted
UINFO(9, " relinVarRef "<<nodep<<endl);
nodep->name(nodep->varp()->name());
}
nodep->iterateChildren(*this);
}
virtual void visit(AstIfaceRefDType* nodep, AstNUser*) {
// May have changed cell names
// TypeTable is always after all modules, so names are stable
UINFO(8," IFACEREFDTYPE "<<nodep<<endl);
if (nodep->cellp()) nodep->cellName(nodep->cellp()->name());
UINFO(8," rename to "<<nodep<<endl);
nodep->iterateChildren(*this);
}
//-------------------- //--------------------
virtual void visit(AstNode* nodep, AstNUser*) { virtual void visit(AstNode* nodep, AstNUser*) {
nodep->iterateChildren(*this); nodep->iterateChildren(*this);

View File

@ -0,0 +1,18 @@
#!/usr/bin/perl
if (!$::Driver) { use FindBin; exec("$FindBin::Bin/bootstrap.pl", @ARGV, $0); die; }
# DESCRIPTION: Verilator: Verilog Test driver/expect definition
#
# Copyright 2003-2009 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.
compile (
);
execute (
check_finished=>1,
);
ok(1);
1;

View File

@ -0,0 +1,31 @@
// DESCRIPTION: Verilator: Verilog Test module
//
// This file ONLY is placed into the Public Domain, for any use,
// without warranty.
// bug998
interface intf
#(parameter PARAM = 0)
();
logic val;
endinterface
module t1(intf mod_intf);
initial begin
$display("%d", mod_intf.val);
end
endmodule
module t();
generate
begin : TestIf
intf #(.PARAM(1)) my_intf;
t1 t (.mod_intf(my_intf));
initial begin
$write("*-* All Finished *-*\n");
$finish;
end
end
endgenerate
endmodule