Fix package:scope.scope variable references.

This commit is contained in:
Wilson Snyder 2015-10-23 21:03:35 -04:00
parent 4fde6ee7af
commit 17a3f9691d
4 changed files with 47 additions and 3 deletions

View File

@ -25,6 +25,8 @@ indicates the contributor was also the author of the fix; Thanks!
**** Fix mis-optimizing public DPI functions, bug963. [Wei Song] **** Fix mis-optimizing public DPI functions, bug963. [Wei Song]
**** Fix package:scope.scope variable references.
* Verilator 3.876 2015-08-12 * Verilator 3.876 2015-08-12

View File

@ -1491,7 +1491,7 @@ private:
if (nodep->user3SetOnce()) return; if (nodep->user3SetOnce()) return;
UINFO(8," "<<nodep<<endl); UINFO(8," "<<nodep<<endl);
DotStates lastStates = m_ds; DotStates lastStates = m_ds;
bool start = !m_ds.m_dotp; // Save, as m_dotp will be changed bool start = (m_ds.m_dotPos == DP_NONE); // Save, as m_dotp will be changed
{ {
if (start) { // Starting dot sequence if (start) { // Starting dot sequence
if (debug()>=9) nodep->dumpTree("-dot-in: "); if (debug()>=9) nodep->dumpTree("-dot-in: ");
@ -1502,7 +1502,7 @@ private:
// m_ds.m_dotText communicates the cell prefix between stages // m_ds.m_dotText communicates the cell prefix between stages
if (nodep->lhsp()->castPackageRef()) { if (nodep->lhsp()->castPackageRef()) {
if (!start) { nodep->lhsp()->v3error("Package reference may not be embedded in dotted reference"); m_ds.m_dotErr=true; } //if (!start) { nodep->lhsp()->v3error("Package reference may not be embedded in dotted reference"); m_ds.m_dotErr=true; }
m_ds.m_dotPos = DP_PACKAGE; m_ds.m_dotPos = DP_PACKAGE;
} else { } else {
m_ds.m_dotPos = DP_SCOPE; m_ds.m_dotPos = DP_SCOPE;
@ -1552,7 +1552,7 @@ private:
if (!m_ds.m_dotSymp) nodep->v3fatalSrc("NULL lookup symbol table"); if (!m_ds.m_dotSymp) nodep->v3fatalSrc("NULL lookup symbol table");
if (!m_statep->forPrimary()) nodep->v3fatalSrc("ParseRefs should no longer exist"); if (!m_statep->forPrimary()) nodep->v3fatalSrc("ParseRefs should no longer exist");
DotStates lastStates = m_ds; DotStates lastStates = m_ds;
bool start = !m_ds.m_dotp; bool start = (m_ds.m_dotPos == DP_NONE); // Save, as m_dotp will be changed
if (start) { if (start) {
m_ds.init(m_curSymp); m_ds.init(m_curSymp);
// Note m_ds.m_dot remains NULL; this is a reference not under a dot // Note m_ds.m_dot remains NULL; this is a reference not under a dot

18
test_regress/t/t_package_dot.pl Executable file
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 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,24 @@
// DESCRIPTION: Verilator: Verilog Test module
//
// This file ONLY is placed into the Public Domain, for any use,
// without warranty, 2015 by Wilson Snyder.
package pkg;
typedef struct packed {
logic [3:0] msk;
logic [3:0] dat;
} STR_t;
endpackage;
package csr_pkg;
typedef pkg::STR_t reg_t;
localparam reg_t REG_RST = 8'h34;
endpackage
module t (/*AUTOARG*/);
initial begin
if (csr_pkg::REG_RST.msk != 4'h3) $stop;
$write("*-* All Finished *-*\n");
$finish;
end
endmodule