3
0
Fork 0
mirror of https://github.com/YosysHQ/yosys synced 2025-04-03 16:19:58 +00:00

Merge pull request #4733 from antmicro/fix-setundef-pass-for-params

Fix setting bits of parameters in setundef pass
This commit is contained in:
Emil J 2025-03-28 13:06:04 +01:00 committed by GitHub
commit ec8b745929
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
3 changed files with 19 additions and 1 deletions

View file

@ -243,7 +243,7 @@ struct SetundefPass : public Pass {
{
for (auto *cell : module->selected_cells()) {
for (auto &parameter : cell->parameters) {
for (auto bit : parameter.second) {
for (auto &bit : parameter.second.bits()) {
if (bit > RTLIL::State::S1)
bit = worker.next_bit();
}

10
tests/various/setundef.sv Normal file
View file

@ -0,0 +1,10 @@
module foo #(parameter [1:0] a) (output [1:0] o);
assign o = a;
endmodule
module top(output [1:0] o);
foo #(2'b0x) foo(o);
always_comb begin
assert(o == 2'b00);
end
endmodule

View file

@ -0,0 +1,8 @@
read_verilog -sv setundef.sv
setundef -zero -params
hierarchy -top top
flatten
proc
async2sync
write_json
sat -seq 5 -prove-asserts