mirror of
https://github.com/YosysHQ/yosys
synced 2025-04-06 01:24:10 +00:00
For connection `assign a = b;`, `sigmap(a)` returns `b`. This is
exactly the opposite of the desired canonicalization for driven bits.
Consider the following code:
module foo(inout a, b);
assign a = b;
endmodule
module bar(output c);
foo f(c, 1'b0);
endmodule
Before this commit, the inout ports would be swapped after flattening
(and cause a crash while attempting to drive a constant value).
This issue was introduced in 9f772eb9
.
Fixes #2183.
12 lines
152 B
Plaintext
12 lines
152 B
Plaintext
read_verilog <<EOT
|
|
module foo(inout a, b);
|
|
assign a = b;
|
|
endmodule
|
|
module bar(output c);
|
|
foo f(c, 1'b0);
|
|
endmodule
|
|
EOT
|
|
|
|
hierarchy -auto-top
|
|
flatten
|