mirror of
https://github.com/verilator/verilator.git
synced 2025-04-05 04:02:37 +00:00
`$psprintf` is a non-standard system function present in some other simulators, and has been rejected for standardization by IEEE because of being basically the same as `$sformatf`. To encourage users to fix their codebase, a warning is emitted by default, but it gets otherwise interpreted as `$sformatf` as early as during lexing. Signed-off-by: Arkadiusz Kozdra <akozdra@antmicro.com> * wording/formatting Signed-off-by: Arkadiusz Kozdra <akozdra@antmicro.com> --------- Signed-off-by: Arkadiusz Kozdra <akozdra@antmicro.com>
This commit is contained in:
parent
02dd33b60e
commit
d4c3e35f97
@ -1217,6 +1217,14 @@ List Of Warnings
|
|||||||
:vlopt:`--no-timing` option.
|
:vlopt:`--no-timing` option.
|
||||||
|
|
||||||
|
|
||||||
|
.. option:: NONSTD
|
||||||
|
|
||||||
|
Warns when a non-standard language feature is used that has a standard
|
||||||
|
equivalent, which might behave differently in corner cases. For example
|
||||||
|
:code:`$psprintf` system function is replaced by its standard equivalent
|
||||||
|
:code:`$sformatf`.
|
||||||
|
|
||||||
|
|
||||||
.. option:: NULLPORT
|
.. option:: NULLPORT
|
||||||
|
|
||||||
Warns that a null port was detected in the module definition port
|
Warns that a null port was detected in the module definition port
|
||||||
|
@ -121,6 +121,7 @@ public:
|
|||||||
MULTITOP, // Multiple top level modules
|
MULTITOP, // Multiple top level modules
|
||||||
NEWERSTD, // Newer language standard required
|
NEWERSTD, // Newer language standard required
|
||||||
NOLATCH, // No latch detected in always_latch block
|
NOLATCH, // No latch detected in always_latch block
|
||||||
|
NONSTD, // Non-standard feature present in other sims
|
||||||
NULLPORT, // Null port detected in module definition
|
NULLPORT, // Null port detected in module definition
|
||||||
PINCONNECTEMPTY,// Cell pin connected by name with empty reference
|
PINCONNECTEMPTY,// Cell pin connected by name with empty reference
|
||||||
PINMISSING, // Cell pin not specified
|
PINMISSING, // Cell pin not specified
|
||||||
@ -204,7 +205,7 @@ public:
|
|||||||
"IMPERFECTSCH", "IMPLICIT", "IMPLICITSTATIC", "IMPORTSTAR", "IMPURE",
|
"IMPERFECTSCH", "IMPLICIT", "IMPLICITSTATIC", "IMPORTSTAR", "IMPURE",
|
||||||
"INCABSPATH", "INFINITELOOP", "INITIALDLY", "INSECURE",
|
"INCABSPATH", "INFINITELOOP", "INITIALDLY", "INSECURE",
|
||||||
"LATCH", "LITENDIAN", "MINTYPMAXDLY", "MISINDENT", "MODDUP",
|
"LATCH", "LITENDIAN", "MINTYPMAXDLY", "MISINDENT", "MODDUP",
|
||||||
"MULTIDRIVEN", "MULTITOP", "NEWERSTD", "NOLATCH", "NULLPORT", "PINCONNECTEMPTY",
|
"MULTIDRIVEN", "MULTITOP", "NEWERSTD", "NOLATCH", "NONSTD", "NULLPORT", "PINCONNECTEMPTY",
|
||||||
"PINMISSING", "PINNOCONNECT", "PINNOTFOUND", "PKGNODECL", "PREPROCZERO", "PROCASSWIRE",
|
"PINMISSING", "PINNOCONNECT", "PINNOTFOUND", "PKGNODECL", "PREPROCZERO", "PROCASSWIRE",
|
||||||
"PROFOUTOFDATE", "PROTECTED", "RANDC", "REALCVT", "REDEFMACRO", "RISEFALLDLY",
|
"PROFOUTOFDATE", "PROTECTED", "RANDC", "REALCVT", "REDEFMACRO", "RISEFALLDLY",
|
||||||
"SELRANGE", "SHORTREAL", "SIDEEFFECT", "SPLITVAR",
|
"SELRANGE", "SHORTREAL", "SIDEEFFECT", "SPLITVAR",
|
||||||
|
@ -251,6 +251,9 @@ vnum {vnum1}|{vnum2}|{vnum3}|{vnum4}|{vnum5}
|
|||||||
"$period" { FL; return yaTIMINGSPEC; }
|
"$period" { FL; return yaTIMINGSPEC; }
|
||||||
"$pow" { FL; return yD_POW; }
|
"$pow" { FL; return yD_POW; }
|
||||||
"$printtimescale" { FL; return yD_PRINTTIMESCALE; }
|
"$printtimescale" { FL; return yD_PRINTTIMESCALE; }
|
||||||
|
"$psprintf" { FL; yylval.fl->v3warn(NONSTD, "Non-standard system function '" << yytext << "';"
|
||||||
|
" suggest use standard '$sformatf' (IEEE 1800-2023 21.3.3)");
|
||||||
|
return yD_SFORMATF; }
|
||||||
"$random" { FL; return yD_RANDOM; }
|
"$random" { FL; return yD_RANDOM; }
|
||||||
"$readmemb" { FL; return yD_READMEMB; }
|
"$readmemb" { FL; return yD_READMEMB; }
|
||||||
"$readmemh" { FL; return yD_READMEMH; }
|
"$readmemh" { FL; return yD_READMEMH; }
|
||||||
|
22
test_regress/t/t_sys_psprintf.pl
Executable file
22
test_regress/t/t_sys_psprintf.pl
Executable file
@ -0,0 +1,22 @@
|
|||||||
|
#!/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);
|
||||||
|
|
||||||
|
compile(
|
||||||
|
verilator_flags2 => ['-Wno-NONSTD'],
|
||||||
|
);
|
||||||
|
|
||||||
|
execute(
|
||||||
|
check_finished => 1,
|
||||||
|
);
|
||||||
|
|
||||||
|
ok(1);
|
||||||
|
1;
|
29
test_regress/t/t_sys_psprintf.v
Normal file
29
test_regress/t/t_sys_psprintf.v
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
// DESCRIPTION: Verilator: Verilog Test module
|
||||||
|
//
|
||||||
|
// This file ONLY is placed under the Creative Commons Public Domain, for
|
||||||
|
// any use, without warranty, 2024 by Antmicro Ltd.
|
||||||
|
// SPDX-License-Identifier: CC0-1.0
|
||||||
|
|
||||||
|
module t;
|
||||||
|
|
||||||
|
// Note $sformatf already tested elsewhere
|
||||||
|
|
||||||
|
reg [3:0] n;
|
||||||
|
reg [63:0] q;
|
||||||
|
reg [16*8:1] wide;
|
||||||
|
|
||||||
|
string str;
|
||||||
|
|
||||||
|
initial begin
|
||||||
|
n = 4'b1100;
|
||||||
|
q = 64'h1234_5678_abcd_0123;
|
||||||
|
wide = "hello-there12345";
|
||||||
|
str = $psprintf("n=%b q=%d w=%s", n, q, wide);
|
||||||
|
`ifdef TEST_VERBOSE $display("str=%0s",str); `endif
|
||||||
|
if (str !== "n=1100 q= 1311768467750060323 w=hello-there12345") $stop;
|
||||||
|
|
||||||
|
$write("*-* All Finished *-*\n");
|
||||||
|
$finish;
|
||||||
|
end
|
||||||
|
|
||||||
|
endmodule
|
6
test_regress/t/t_sys_psprintf_warn_bad.out
Normal file
6
test_regress/t/t_sys_psprintf_warn_bad.out
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
%Warning-NONSTD: t/t_sys_psprintf.v:21:13: Non-standard system function '$psprintf'; suggest use standard '$sformatf' (IEEE 1800-2023 21.3.3)
|
||||||
|
21 | str = $psprintf("n=%b q=%d w=%s", n, q, wide);
|
||||||
|
| ^~~~~~~~~
|
||||||
|
... For warning description see https://verilator.org/warn/NONSTD?v=latest
|
||||||
|
... Use "/* verilator lint_off NONSTD */" and lint_on around source to disable this message.
|
||||||
|
%Error: Exiting due to
|
21
test_regress/t/t_sys_psprintf_warn_bad.pl
Executable file
21
test_regress/t/t_sys_psprintf_warn_bad.pl
Executable file
@ -0,0 +1,21 @@
|
|||||||
|
#!/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(vlt => 1);
|
||||||
|
|
||||||
|
top_filename("t/t_sys_psprintf.v");
|
||||||
|
|
||||||
|
lint(
|
||||||
|
fails => 1,
|
||||||
|
expect_filename => $Self->{golden_filename},
|
||||||
|
);
|
||||||
|
|
||||||
|
ok(1);
|
||||||
|
1;
|
Loading…
Reference in New Issue
Block a user