mirror of
https://github.com/verilator/verilator.git
synced 2025-04-05 20:22:41 +00:00
Fix function references under top inlined module.
git-svn-id: file://localhost/svn/verilator/trunk/verilator@781 77ca24e4-aefa-0310-84f0-b9a241c72d87
This commit is contained in:
parent
1b20481100
commit
88809587f9
6
Changes
6
Changes
@ -3,7 +3,11 @@ Revision history for Verilator
|
|||||||
The contributors that suggested a given feature are shown in []. [by ...]
|
The contributors that suggested a given feature are shown in []. [by ...]
|
||||||
indicates the contributor was also the author of the fix; Thanks!
|
indicates the contributor was also the author of the fix; Thanks!
|
||||||
|
|
||||||
* Verilator 3.601 09/06/2006
|
* Verilator 3.602 ****
|
||||||
|
|
||||||
|
**** Fix function references under top inlined module. [David Hewson]
|
||||||
|
|
||||||
|
* Verilator 3.601 09/06/2006 Beta
|
||||||
|
|
||||||
*** Added --inhibit-sim flag for environments using old __Vm_inhibitSim.
|
*** Added --inhibit-sim flag for environments using old __Vm_inhibitSim.
|
||||||
|
|
||||||
|
@ -546,7 +546,8 @@ private:
|
|||||||
string baddot;
|
string baddot;
|
||||||
LinkDotBaseVertex* dotVxp = m_cellVxp; // Start search at current scope
|
LinkDotBaseVertex* dotVxp = m_cellVxp; // Start search at current scope
|
||||||
if (nodep->inlinedDots()!="") { // Correct for current scope
|
if (nodep->inlinedDots()!="") { // Correct for current scope
|
||||||
dotVxp = m_statep->findDotted(dotVxp, nodep->inlinedDots(), baddot);
|
string inl = AstNode::prettyName(nodep->inlinedDots());
|
||||||
|
dotVxp = m_statep->findDotted(dotVxp, inl, baddot);
|
||||||
if (!dotVxp) nodep->v3fatalSrc("Couldn't resolve inlined scope '"<<baddot<<"' in: "<<nodep->inlinedDots());
|
if (!dotVxp) nodep->v3fatalSrc("Couldn't resolve inlined scope '"<<baddot<<"' in: "<<nodep->inlinedDots());
|
||||||
}
|
}
|
||||||
dotVxp = m_statep->findDotted(dotVxp, nodep->dotted(), baddot); // Maybe NULL
|
dotVxp = m_statep->findDotted(dotVxp, nodep->dotted(), baddot); // Maybe NULL
|
||||||
@ -589,7 +590,9 @@ private:
|
|||||||
string baddot;
|
string baddot;
|
||||||
LinkDotBaseVertex* dotVxp = m_cellVxp; // Start search at current scope
|
LinkDotBaseVertex* dotVxp = m_cellVxp; // Start search at current scope
|
||||||
if (nodep->inlinedDots()!="") { // Correct for current scope
|
if (nodep->inlinedDots()!="") { // Correct for current scope
|
||||||
dotVxp = m_statep->findDotted(dotVxp, nodep->inlinedDots(), baddot);
|
string inl = AstNode::prettyName(nodep->inlinedDots());
|
||||||
|
UINFO(8,"\t\tInlined "<<inl<<endl);
|
||||||
|
dotVxp = m_statep->findDotted(dotVxp, inl, baddot);
|
||||||
if (!dotVxp) nodep->v3fatalSrc("Couldn't resolve inlined scope '"<<baddot<<"' in: "<<nodep->inlinedDots());
|
if (!dotVxp) nodep->v3fatalSrc("Couldn't resolve inlined scope '"<<baddot<<"' in: "<<nodep->inlinedDots());
|
||||||
}
|
}
|
||||||
dotVxp = m_statep->findDotted(dotVxp, nodep->dotted(), baddot); // Maybe NULL
|
dotVxp = m_statep->findDotted(dotVxp, nodep->dotted(), baddot); // Maybe NULL
|
||||||
|
14
test_regress/t/t_func_lib_sub.pl
Executable file
14
test_regress/t/t_func_lib_sub.pl
Executable file
@ -0,0 +1,14 @@
|
|||||||
|
#!/usr/bin/perl
|
||||||
|
if (!$::Driver) { use FindBin; exec("./driver.pl", @ARGV, $0); die; }
|
||||||
|
# $Id$
|
||||||
|
# DESCRIPTION: Verilator: Verilog Test driver/expect definition
|
||||||
|
#
|
||||||
|
# Copyright 2003 by Wilson Snyder. This program is free software; you can
|
||||||
|
# redistribute it and/or modify it under the terms of either the GNU
|
||||||
|
# General Public License or the Perl Artistic License.
|
||||||
|
|
||||||
|
compile (
|
||||||
|
);
|
||||||
|
# No execute
|
||||||
|
ok(1);
|
||||||
|
1;
|
Loading…
Reference in New Issue
Block a user