From eb66e137db579c876d7a267046de5a2967aa479c Mon Sep 17 00:00:00 2001 From: Wilson Snyder Date: Fri, 13 Sep 2024 18:31:55 -0400 Subject: [PATCH] Fix fault on defparam with UNSUPPORTED ignored (#5450). --- Changes | 2 +- src/verilog.y | 8 +++++--- test_regress/t/t_gen_defparam_bad.out | 11 +++++++++++ test_regress/t/t_gen_defparam_bad.py | 16 ++++++++++++++++ test_regress/t/t_gen_defparam_bad.v | 12 ++++++++++++ 5 files changed, 45 insertions(+), 4 deletions(-) create mode 100644 test_regress/t/t_gen_defparam_bad.out create mode 100755 test_regress/t/t_gen_defparam_bad.py create mode 100644 test_regress/t/t_gen_defparam_bad.v diff --git a/Changes b/Changes index 94f5d189c..bf85ba903 100644 --- a/Changes +++ b/Changes @@ -42,7 +42,7 @@ Verilator 5.029 devel * Fix clearing trigger of events with no sensitivity trees (#5426). [Arkadiusz Kozdra, Antmicro Ltd.] * Fix driving clocking block in reactive region (#5430). [Krzysztof Bieganski, Antmicro Ltd.] * Fix associative array next/prev/first/last mis-propagating constants (#5435). [Ethan Sifferman] - +* Fix fault on defparam with UNSUPPORTED ignored (#5450). [Luiza de Melo] Verilator 5.028 2024-08-21 diff --git a/src/verilog.y b/src/verilog.y index e20da0387..838da1d6d 100644 --- a/src/verilog.y +++ b/src/verilog.y @@ -3182,12 +3182,14 @@ type_assignment: // ==IEEE: type_assignment list_of_type_assignments: // ==IEEE: list_of_type_assignments type_assignment { $$ = $1; } - | list_of_type_assignments ',' type_assignment { $$ = $1->addNext($3); } + | list_of_type_assignments ',' type_assignment + { $$ = addNextNull($1, $3); } ; list_of_defparam_assignments: //== IEEE: list_of_defparam_assignments defparam_assignment { $$ = $1; } - | list_of_defparam_assignments ',' defparam_assignment { $$ = $1->addNext($3); } + | list_of_defparam_assignments ',' defparam_assignment + { $$ = addNextNull($1, $3); } ; defparam_assignment: // ==IEEE: defparam_assignment @@ -5615,7 +5617,7 @@ gateXorPinList: ; gateUnsupPinList: gatePinExpr { $$ = $1; } - | gateUnsupPinList ',' gatePinExpr { $$ = $1->addNext($3); } + | gateUnsupPinList ',' gatePinExpr { $$ = addNextNull($1, $3); } ; gatePinExpr: diff --git a/test_regress/t/t_gen_defparam_bad.out b/test_regress/t/t_gen_defparam_bad.out new file mode 100644 index 000000000..2cf6e7073 --- /dev/null +++ b/test_regress/t/t_gen_defparam_bad.out @@ -0,0 +1,11 @@ +%Error-UNSUPPORTED: t/t_gen_defparam_bad.v:9:12: Unsupported: defparam with no dot + 9 | id_15 = id_14; + | ^ + ... For error description see https://verilator.org/warn/UNSUPPORTED?v=latest +%Error-UNSUPPORTED: t/t_gen_defparam_bad.v:11:18: Unsupported: defparam with no dot + 11 | defparam id_8 = 1, id_9 = 1; + | ^ +%Error-UNSUPPORTED: t/t_gen_defparam_bad.v:11:28: Unsupported: defparam with no dot + 11 | defparam id_8 = 1, id_9 = 1; + | ^ +%Error: Exiting due to diff --git a/test_regress/t/t_gen_defparam_bad.py b/test_regress/t/t_gen_defparam_bad.py new file mode 100755 index 000000000..e33e10acf --- /dev/null +++ b/test_regress/t/t_gen_defparam_bad.py @@ -0,0 +1,16 @@ +#!/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(fails=True, expect_filename=test.golden_filename) + +test.passes() diff --git a/test_regress/t/t_gen_defparam_bad.v b/test_regress/t/t_gen_defparam_bad.v new file mode 100644 index 000000000..ec0e08d44 --- /dev/null +++ b/test_regress/t/t_gen_defparam_bad.v @@ -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(/*AUTOARG*/); + defparam id_13.id_14 = -id_13, + id_15 = id_14; + + defparam id_8 = 1, id_9 = 1; +endmodule