Fix assertion failure in V3Gate (#5101)

This commit is contained in:
Yutetsu TAKATSUKASA 2024-06-08 21:37:01 +09:00 committed by GitHub
parent 9ff06c1664
commit 6584b4d426
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
3 changed files with 64 additions and 0 deletions

View File

@ -656,6 +656,9 @@ public:
return m_substitutionp; return m_substitutionp;
} }
const std::vector<AstVarScope*>& readVscps() const { return m_readVscps; } const std::vector<AstVarScope*>& readVscps() const { return m_readVscps; }
bool varAssigned(const AstVarScope* scopep) const {
return m_lhsVarRef && (m_lhsVarRef->varScopep() == scopep);
}
}; };
//###################################################################### //######################################################################
@ -772,6 +775,8 @@ class GateInline final {
// Was it ok? // Was it ok?
if (!okVisitor.isSimple()) continue; if (!okVisitor.isSimple()) continue;
// If the varScope is already removed from logicp, no need to try substitution.
if (!okVisitor.varAssigned(vVtxp->varScp())) continue;
// Does it read multiple source variables? // Does it read multiple source variables?
if (okVisitor.readVscps().size() > 1) { if (okVisitor.readVscps().size() > 1) {
@ -822,6 +827,8 @@ class GateInline final {
if (debug() >= 9) dstVtxp->nodep()->dumpTree(" inside: "); if (debug() >= 9) dstVtxp->nodep()->dumpTree(" inside: ");
UASSERT_OBJ(logicp != dstVtxp->nodep(), logicp,
"Circular logic should have been rejected by okVisitor");
recordSubstitution(vscp, substp, dstVtxp->nodep()); recordSubstitution(vscp, substp, dstVtxp->nodep());
// If the new replacement referred to a signal, // If the new replacement referred to a signal,

20
test_regress/t/t_gate_opt.pl Executable file
View File

@ -0,0 +1,20 @@
#!/usr/bin/env perl
if (!$::Driver) { use FindBin; exec("$FindBin::Bin/bootstrap.pl", @ARGV, $0); die; }
# DESCRIPTION: Verilator: Verilog Test driver/expect definition
#
# Copyright 2003 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();
execute(
check_finished => 1,
);
ok(1);
1;

View File

@ -0,0 +1,37 @@
// DESCRIPTION: Verilator: Verilog Test module
//
// This file ONLY is placed under the Creative Commons Public Domain, for
// any use, without warranty, 2024 by Yutetsu TAKATSUKASA.
// SPDX-License-Identifier: CC0-1.0
// bug5101
module t ();
logic [1:0] in0, in1, out;
logic sel;
assign in0 = 1;
assign in1 = 2;
assign sel = 1'b1;
initial begin
$display("out:%d", out);
$write("*-* All Finished *-*\n");
$finish;
end
bug5101 u_bug5101(.in0, .in1, .sel, .out);
endmodule
module bug5101(input wire [1:0] in0, input wire [1:0] in1, input wire sel, output logic [1:0] out);
// verilator no_inline_module
function logic [1:0] incr(input [1:0] in);
logic [1:0] tmp;
tmp = in + 1;
return tmp;
endfunction
always_comb
if (sel) out = in0;
else out = incr(in1);
endmodule