Add --[no]-stop-fail option (#4904)

Co-authored-by: Wilson Snyder <wsnyder@wsnyder.org>
This commit is contained in:
Yutetsu TAKATSUKASA 2024-02-19 21:26:58 +09:00 committed by GitHub
parent a187a16e56
commit a951446f9b
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
7 changed files with 45 additions and 1 deletions

View File

@ -437,6 +437,7 @@ detailed descriptions of these arguments.
--stats Create statistics file --stats Create statistics file
--stats-vars Provide statistics on variables --stats-vars Provide statistics on variables
--no-std Prevent parsing standard library --no-std Prevent parsing standard library
--no-stop-fail Do not call $stop when assertion fails
--structs-packed Convert all unpacked structures to packed structures --structs-packed Convert all unpacked structures to packed structures
-sv Enable SystemVerilog parsing -sv Enable SystemVerilog parsing
+systemverilogext+<ext> Synonym for +1800-2017ext+<ext> +systemverilogext+<ext> Synonym for +1800-2017ext+<ext>

View File

@ -1280,6 +1280,10 @@ Summary:
Prevents parsing standard library. Prevents parsing standard library.
.. option:: --no-stop-fail
Don't call $stop when assertion fails. Simulation will continue.
.. option:: --structs-packed .. option:: --structs-packed
Converts all unpacked structures to packed structures, and issues an Converts all unpacked structures to packed structures, and issues an

View File

@ -127,7 +127,7 @@ class AssertVisitor final : public VNVisitor {
AstNode* const bodysp = dispp; AstNode* const bodysp = dispp;
replaceDisplay(dispp, "%%Error"); // Convert to standard DISPLAY format replaceDisplay(dispp, "%%Error"); // Convert to standard DISPLAY format
if (exprsp) dispp->fmtp()->exprsp()->addNext(exprsp); if (exprsp) dispp->fmtp()->exprsp()->addNext(exprsp);
bodysp->addNext(new AstStop{nodep->fileline(), true}); if (v3Global.opt.stopFail()) bodysp->addNext(new AstStop{nodep->fileline(), true});
return bodysp; return bodysp;
} }

View File

@ -1442,6 +1442,7 @@ void V3Options::parseOptsList(FileLine* fl, const string& optdir, int argc,
m_stats |= flag; m_stats |= flag;
}); });
DECL_OPTION("-std", OnOff, &m_std); DECL_OPTION("-std", OnOff, &m_std);
DECL_OPTION("-stop-fail", OnOff, &m_stopFail);
DECL_OPTION("-structs-packed", OnOff, &m_structsPacked); DECL_OPTION("-structs-packed", OnOff, &m_structsPacked);
DECL_OPTION("-sv", CbCall, [this]() { m_defaultLanguage = V3LangCode::L1800_2017; }); DECL_OPTION("-sv", CbCall, [this]() { m_defaultLanguage = V3LangCode::L1800_2017; });

View File

@ -315,6 +315,7 @@ private:
int m_publicDepth = 0; // main switch: --public-depth int m_publicDepth = 0; // main switch: --public-depth
int m_reloopLimit = 40; // main switch: --reloop-limit int m_reloopLimit = 40; // main switch: --reloop-limit
VOptionBool m_skipIdentical; // main switch: --skip-identical VOptionBool m_skipIdentical; // main switch: --skip-identical
bool m_stopFail = true; // main switch: --stop-fail
int m_threads = 1; // main switch: --threads int m_threads = 1; // main switch: --threads
int m_threadsMaxMTasks = 0; // main switch: --threads-max-mtasks int m_threadsMaxMTasks = 0; // main switch: --threads-max-mtasks
VTimescale m_timeDefaultPrec; // main switch: --timescale VTimescale m_timeDefaultPrec; // main switch: --timescale
@ -549,6 +550,7 @@ public:
int publicDepth() const { return m_publicDepth; } int publicDepth() const { return m_publicDepth; }
int reloopLimit() const { return m_reloopLimit; } int reloopLimit() const { return m_reloopLimit; }
VOptionBool skipIdentical() const { return m_skipIdentical; } VOptionBool skipIdentical() const { return m_skipIdentical; }
bool stopFail() const { return m_stopFail; }
int threads() const VL_MT_SAFE { return m_threads; } int threads() const VL_MT_SAFE { return m_threads; }
int threadsMaxMTasks() const { return m_threadsMaxMTasks; } int threadsMaxMTasks() const { return m_threadsMaxMTasks; }
bool mtasks() const { return (m_threads > 1); } bool mtasks() const { return (m_threads > 1); }

View File

@ -0,0 +1,12 @@
match_item0
match_item0
match_item0
match_item0
match_item0
match_item0
match_item0
match_item0
match_item0
[90] %Error: t_assert_unique_case_bad.v:36: Assertion failed in top.t: unique case, but multiple matches found for '12'h388'
*-* All Finished *-*
match_item0

View File

@ -0,0 +1,24 @@
#!/usr/bin/env perl
if (!$::Driver) { use FindBin; exec("$FindBin::Bin/bootstrap.pl", @ARGV, $0); die; }
# 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
scenarios(simulator => 1);
top_filename("t/t_assert_unique_case_bad.v");
compile(
verilator_flags2 => ["-x-assign 0 --assert --no-stop-fail"],
);
execute(
check_finished => 1,
expect_filename => $Self->{golden_filename},
);
ok(1);
1;