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:
commit
ec8b745929
|
@ -243,7 +243,7 @@ struct SetundefPass : public Pass {
|
|||
{
|
||||
for (auto *cell : module->selected_cells()) {
|
||||
for (auto ¶meter : 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
10
tests/various/setundef.sv
Normal 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
|
8
tests/various/setundef.ys
Normal file
8
tests/various/setundef.ys
Normal 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
|
Loading…
Reference in a new issue