Fix ENUMVALUE on typedef (#3777)

This commit is contained in:
Wilson Snyder 2022-12-11 11:50:22 -05:00
parent 86e3c02339
commit 3f4d4dec77
4 changed files with 61 additions and 17 deletions

View File

@ -19,7 +19,7 @@ Verilator 5.003 devel
* Support pre_randomize and post_randomize. * Support pre_randomize and post_randomize.
* Support $timeunit and $timeprecision. * Support $timeunit and $timeprecision.
* Support assignment expressions. * Support assignment expressions.
* Add ENUMVALUE warning when value misused for enum (#726). * Add ENUMVALUE warning when value misused for enum (#726) (#3777).
* Internal AST improvements, also affect XML format (#3721). [Geza Lore] * Internal AST improvements, also affect XML format (#3721). [Geza Lore]
* Change ENDLABEL from warning into an error. * Change ENDLABEL from warning into an error.
* Deprecate verilated_fst_sc.cpp and verilated_vcd_sc.cpp. * Deprecate verilated_fst_sc.cpp and verilated_vcd_sc.cpp.

View File

@ -1941,6 +1941,7 @@ private:
// if (debug()) nodep->backp()->dumpTree("- CastOutUpUp: "); // if (debug()) nodep->backp()->dumpTree("- CastOutUpUp: ");
} }
if (m_vup->final()) { if (m_vup->final()) {
// if (debug()) nodep->dumpTree(cout, "- CastFPit: ");
iterateCheck(nodep, "value", nodep->fromp(), SELF, FINAL, nodep->fromp()->dtypep(), iterateCheck(nodep, "value", nodep->fromp(), SELF, FINAL, nodep->fromp()->dtypep(),
EXTEND_EXP, false); EXTEND_EXP, false);
AstNode* const underp = nodep->fromp()->unlinkFrBack(); AstNode* const underp = nodep->fromp()->unlinkFrBack();
@ -6966,28 +6967,20 @@ private:
toDtp = toDtp->skipRefToEnump(); toDtp = toDtp->skipRefToEnump();
fromDtp = fromDtp->skipRefToEnump(); fromDtp = fromDtp->skipRefToEnump();
if (toDtp == fromDtp) return COMPATIBLE; if (toDtp == fromDtp) return COMPATIBLE;
const AstNodeDType* fromBaseDtp = fromDtp;
while (const AstPackArrayDType* const packp = VN_CAST(fromBaseDtp, PackArrayDType)) { // UNSUP unpacked struct/unions (treated like BasicDType)
fromBaseDtp = packp->subDTypep(); const AstNodeDType* fromBaseDtp = computeCastableBase(fromDtp);
while (const AstRefDType* const refp = VN_CAST(fromBaseDtp, RefDType)) {
fromBaseDtp = refp->refDTypep();
}
}
const bool fromNumericable = VN_IS(fromBaseDtp, BasicDType) const bool fromNumericable = VN_IS(fromBaseDtp, BasicDType)
|| VN_IS(fromBaseDtp, EnumDType) || VN_IS(fromBaseDtp, EnumDType)
|| VN_IS(fromBaseDtp, NodeUOrStructDType); || VN_IS(fromBaseDtp, NodeUOrStructDType);
const AstNodeDType* toBaseDtp = toDtp; const AstNodeDType* toBaseDtp = computeCastableBase(toDtp);
while (const AstPackArrayDType* const packp = VN_CAST(toBaseDtp, PackArrayDType)) {
toBaseDtp = packp->subDTypep();
while (const AstRefDType* const refp = VN_CAST(toBaseDtp, RefDType)) {
toBaseDtp = refp->refDTypep();
}
}
const bool toNumericable const bool toNumericable
= VN_IS(toBaseDtp, BasicDType) || VN_IS(toBaseDtp, NodeUOrStructDType); = VN_IS(toBaseDtp, BasicDType) || VN_IS(toBaseDtp, NodeUOrStructDType);
// UNSUP unpacked struct/unions (treated like BasicDType)
if (toNumericable) { if (toBaseDtp == fromBaseDtp) {
return COMPATIBLE;
} else if (toNumericable) {
if (fromNumericable) return COMPATIBLE; if (fromNumericable) return COMPATIBLE;
} else if (VN_IS(toDtp, EnumDType)) { } else if (VN_IS(toDtp, EnumDType)) {
if (VN_IS(fromBaseDtp, EnumDType) && toDtp->sameTree(fromDtp)) return ENUM_IMPLICIT; if (VN_IS(fromBaseDtp, EnumDType) && toDtp->sameTree(fromDtp)) return ENUM_IMPLICIT;
@ -7010,6 +7003,20 @@ private:
} }
return castable; return castable;
} }
static const AstNodeDType* computeCastableBase(const AstNodeDType* nodep) {
while (true) {
if (const AstPackArrayDType* const packp = VN_CAST(nodep, PackArrayDType)) {
nodep = packp->subDTypep();
continue;
} else if (const AstNodeDType* const refp = nodep->skipRefToEnump()) {
if (refp != nodep) {
nodep = refp;
continue;
}
}
return nodep;
}
}
//---------------------------------------------------------------------- //----------------------------------------------------------------------
// METHODS - special type detection // METHODS - special type detection

View File

@ -0,0 +1,17 @@
#!/usr/bin/env 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.
# SPDX-License-Identifier: LGPL-3.0-only OR Artistic-2.0
scenarios(linter => 1);
lint(
);
ok(1);
1;

View File

@ -0,0 +1,20 @@
// DESCRIPTION: Verilator: Verilog Test module
//
// This file ONLY is placed under the Creative Commons Public Domain, for
// any use, without warranty, 2022 by Wilson Snyder.
// SPDX-License-Identifier: CC0-1.0
module t
#(
parameter type data_t = logic
)
(
input data_t[7:0] in_data
);
typedef data_t[7:0] in_data_t;
in_data_t out_data;
always_comb out_data = in_data_t'(in_data);
endmodule