Fix enum name method (#5563)

This commit is contained in:
Todd Strader 2024-10-25 18:49:45 -04:00 committed by GitHub
parent 292c2e289e
commit ec2eae607a
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
3 changed files with 68 additions and 0 deletions

View File

@ -209,6 +209,12 @@ protected:
m_packed = (numericUnpack != VSigning::NOSIGN); m_packed = (numericUnpack != VSigning::NOSIGN);
numeric(VSigning::fromBool(numericUnpack.isSigned())); numeric(VSigning::fromBool(numericUnpack.isSigned()));
} }
AstNodeUOrStructDType(const AstNodeUOrStructDType& other)
: AstNodeDType(other)
, m_name(other.m_name)
, m_uniqueNum(uniqueNumInc())
, m_packed(other.m_packed)
, m_isFourstate(other.m_isFourstate) {}
public: public:
ASTGEN_MEMBERS_AstNodeUOrStructDType; ASTGEN_MEMBERS_AstNodeUOrStructDType;
@ -664,6 +670,11 @@ public:
childDTypep(dtp); // Only for parser childDTypep(dtp); // Only for parser
dtypep(nullptr); // V3Width will resolve dtypep(nullptr); // V3Width will resolve
} }
AstDefImplicitDType(const AstDefImplicitDType& other)
: AstNodeDType(other)
, m_name(other.m_name)
, m_containerp(other.m_containerp)
, m_uniqueNum(uniqueNumInc()) {}
ASTGEN_MEMBERS_AstDefImplicitDType; ASTGEN_MEMBERS_AstDefImplicitDType;
int uniqueNum() const { return m_uniqueNum; } int uniqueNum() const { return m_uniqueNum; }
bool same(const AstNode* samep) const override { bool same(const AstNode* samep) const override {
@ -793,6 +804,10 @@ public:
dtypep(nullptr); // V3Width will resolve dtypep(nullptr); // V3Width will resolve
widthFromSub(subDTypep()); widthFromSub(subDTypep());
} }
AstEnumDType(const AstEnumDType& other)
: AstNodeDType(other)
, m_name(other.m_name)
, m_uniqueNum(uniqueNumInc()) {}
ASTGEN_MEMBERS_AstEnumDType; ASTGEN_MEMBERS_AstEnumDType;
const char* broken() const override; const char* broken() const override;

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('simulator')
test.compile()
test.execute()
test.passes()

View File

@ -0,0 +1,35 @@
// DESCRIPTION: Verilator: Demonstrate struct literal param assignment problem
//
// This file ONLY is placed into the Public Domain, for any use,
// without warranty, 2024 by Wilson Snyder.
// SPDX-License-Identifier: CC0-1.0
module sub #(parameter int param_a, parameter bit [1:0] enum_param = '0) ();
typedef enum logic [1:0] {
FOO = enum_param,
BAR,
BAZ
} enum_t;
enum_t the_enum = enum_t'(1);
initial $display("%s", the_enum.name());
endmodule
module t (/*AUTOARG*/
// Inputs
clk
);
input clk;
// finish report
always @ (posedge clk) begin
$write("*-* All Finished *-*\n");
$finish;
end
sub #(.param_a(1)) the_sub1();
sub #(.param_a(2)) the_sub2();
sub #(.param_a(2), .enum_param(2'd1)) the_sub3();
endmodule