Fix to avoid IMPLICIT creation if data type of same name.

This commit is contained in:
Wilson Snyder 2024-09-28 17:58:26 -04:00
parent 1dc6fd3d93
commit 5c923d6629
7 changed files with 73 additions and 4 deletions

View File

@ -3050,8 +3050,7 @@ class LinkDotResolveVisitor final : public VNVisitor {
m_ds.m_dotPos = DP_MEMBER; m_ds.m_dotPos = DP_MEMBER;
} else { } else {
// Cells/interfaces can't be implicit // Cells/interfaces can't be implicit
const bool isCell = foundp ? VN_IS(foundp->nodep(), Cell) : false; const bool checkImplicit = (!m_ds.m_dotp && m_ds.m_dotText == "" && !foundp);
const bool checkImplicit = (!m_ds.m_dotp && m_ds.m_dotText == "" && !isCell);
const bool err const bool err
= !(checkImplicit && m_statep->implicitOk(m_modp, nodep->name())); = !(checkImplicit && m_statep->implicitOk(m_modp, nodep->name()));
if (err) { if (err) {
@ -3086,7 +3085,8 @@ class LinkDotResolveVisitor final : public VNVisitor {
if (checkImplicit) { if (checkImplicit) {
// Create if implicit, and also if error (so only complain once) // Create if implicit, and also if error (so only complain once)
// Else if a scope is allowed, making a signal won't help error cascade // Else if a scope is allowed, making a signal won't help error cascade
auto varp = createImplicitVar(m_curSymp, nodep, m_modp, m_modSymp, err); AstVar* const varp
= createImplicitVar(m_curSymp, nodep, m_modp, m_modSymp, err);
AstVarRef* const newp AstVarRef* const newp
= new AstVarRef{nodep->fileline(), varp, VAccess::READ}; = new AstVarRef{nodep->fileline(), varp, VAccess::READ};
nodep->replaceWith(newp); nodep->replaceWith(newp);
@ -4133,7 +4133,7 @@ void V3LinkDot::linkDotGuts(AstNetlist* rootp, VLinkDotStep step) {
v3Global.rootp()->dumpTreeFile(v3Global.debugFilename("prelinkdot-find.tree")); v3Global.rootp()->dumpTreeFile(v3Global.debugFilename("prelinkdot-find.tree"));
} }
if (step == LDS_PRIMARY || step == LDS_PARAMED) { if (step == LDS_PRIMARY || step == LDS_PARAMED) {
// Initial link stage, resolve parameters // Initial link stage, resolve parameters and interfaces
const LinkDotParamVisitor visitors{rootp, &state}; const LinkDotParamVisitor visitors{rootp, &state};
if (dumpTreeEitherLevel() >= 9) { if (dumpTreeEitherLevel() >= 9) {
V3Global::dumpCheckGlobalTree("prelinkdot-param"); V3Global::dumpCheckGlobalTree("prelinkdot-param");

View File

@ -0,0 +1,4 @@
%Error: t/t_lint_implicit_func_bad.v:12:11: Illegal call of a task as a function: 'imp_func_conflict'
12 | assign imp_func_conflict = 1'b1;
| ^~~~~~~~~~~~~~~~~
%Error: Exiting due to

View File

@ -0,0 +1,18 @@
#!/usr/bin/env python3
# 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
import vltest_bootstrap
test.scenarios('vlt')
test.lint(verilator_flags2=["--lint-only -Wall -Wno-DECLFILENAME"],
fails=True,
expect_filename=test.golden_filename)
test.passes()

View File

@ -0,0 +1,13 @@
// DESCRIPTION: Verilator: Verilog Test module
//
// This file ONLY is placed under the Creative Commons Public Domain, for
// any use, without warranty, 2024 by Wilson Snyder.
// SPDX-License-Identifier: CC0-1.0
module t;
function void imp_func_conflict();
endfunction
`default_nettype wire
assign imp_func_conflict = 1'b1;
endmodule

View File

@ -0,0 +1,4 @@
%Error: t/t_lint_implicit_type_bad.v:11:11: syntax error, unexpected TYPE-IDENTIFIER
11 | assign imp_type_conflict = 1'b1;
| ^~~~~~~~~~~~~~~~~
%Error: Exiting due to

View File

@ -0,0 +1,18 @@
#!/usr/bin/env python3
# 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
import vltest_bootstrap
test.scenarios('vlt')
test.lint(verilator_flags2=["--lint-only -Wall -Wno-DECLFILENAME"],
fails=True,
expect_filename=test.golden_filename)
test.passes()

View File

@ -0,0 +1,12 @@
// DESCRIPTION: Verilator: Verilog Test module
//
// This file ONLY is placed under the Creative Commons Public Domain, for
// any use, without warranty, 2024 by Wilson Snyder.
// SPDX-License-Identifier: CC0-1.0
module t;
typedef int imp_type_conflict;
`default_nettype wire
assign imp_type_conflict = 1'b1;
endmodule