From 0dce97b09dfb80f4c1d037d524ede3cc35a722e1 Mon Sep 17 00:00:00 2001 From: Ryszard Rozak Date: Tue, 15 Oct 2024 13:35:59 +0200 Subject: [PATCH] Fix assignments of concatenation to queues and dynamic arrays (#5540) --- src/V3Width.cpp | 14 ++++++++++---- test_regress/t/t_queue_concat_assign.py | 18 ++++++++++++++++++ test_regress/t/t_queue_concat_assign.v | 23 +++++++++++++++++++++++ 3 files changed, 51 insertions(+), 4 deletions(-) create mode 100755 test_regress/t/t_queue_concat_assign.py create mode 100644 test_regress/t/t_queue_concat_assign.v diff --git a/src/V3Width.cpp b/src/V3Width.cpp index 0c1c27d63..9a062f009 100644 --- a/src/V3Width.cpp +++ b/src/V3Width.cpp @@ -4622,9 +4622,12 @@ class WidthVisitor final : public VNVisitor { for (AstPatMember* patp = VN_AS(nodep->itemsp(), PatMember); patp; patp = VN_AS(patp->nextp(), PatMember)) { patp->dtypep(arrayp->subDTypep()); - AstNodeExpr* const valuep = patternMemberValueIterate(patp); + AstNodeExpr* const rhsp = patternMemberValueIterate(patp); + const bool rhsIsValue + = AstNode::computeCastable(rhsp->dtypep(), arrayp->subDTypep(), nullptr) + .isAssignable(); AstConsDynArray* const newap - = new AstConsDynArray{nodep->fileline(), true, valuep, false, newp}; + = new AstConsDynArray{nodep->fileline(), rhsIsValue, rhsp, false, newp}; newap->dtypeFrom(arrayp); newp = newap; } @@ -4638,9 +4641,12 @@ class WidthVisitor final : public VNVisitor { for (AstPatMember* patp = VN_AS(nodep->itemsp(), PatMember); patp; patp = VN_AS(patp->nextp(), PatMember)) { patp->dtypep(arrayp->subDTypep()); - AstNodeExpr* const valuep = patternMemberValueIterate(patp); + AstNodeExpr* const rhsp = patternMemberValueIterate(patp); + const bool rhsIsValue + = AstNode::computeCastable(rhsp->dtypep(), arrayp->subDTypep(), nullptr) + .isAssignable(); AstConsQueue* const newap - = new AstConsQueue{nodep->fileline(), true, valuep, false, newp}; + = new AstConsQueue{nodep->fileline(), rhsIsValue, rhsp, false, newp}; newap->dtypeFrom(arrayp); newp = newap; } diff --git a/test_regress/t/t_queue_concat_assign.py b/test_regress/t/t_queue_concat_assign.py new file mode 100755 index 000000000..d4f986441 --- /dev/null +++ b/test_regress/t/t_queue_concat_assign.py @@ -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() diff --git a/test_regress/t/t_queue_concat_assign.v b/test_regress/t/t_queue_concat_assign.v new file mode 100644 index 000000000..b3860878e --- /dev/null +++ b/test_regress/t/t_queue_concat_assign.v @@ -0,0 +1,23 @@ +// DESCRIPTION: Verilator: Verilog Test module +// +// This file ONLY is placed under the Creative Commons Public Domain, for +// any use, without warranty, 2024 by Antmicro. +// SPDX-License-Identifier: CC0-1.0 + +module t (/*AUTOARG*/); + initial begin + bit q1[$] = {1'b1}; + bit q2[$]; + bit [1:0] d1[] = {2'b10}; + bit [1:0] d2[]; + q2 = {q1}; + if (q2[0] != 1) $stop; + + d2 = {2'b11}; + if (d2[0] != 2'b11) $stop; + + $write("*-* All Finished *-*\n"); + $finish; + end + +endmodule