diff options
| author | whitequark <whitequark@whitequark.org> | 2020-08-26 16:20:32 +0000 | 
|---|---|---|
| committer | whitequark <whitequark@whitequark.org> | 2020-08-26 16:29:42 +0000 | 
| commit | 9f0892159ebb88964839ea2cb5313ef1b87c624d (patch) | |
| tree | afc5f41b1f62874253621d052e4a55eb4aab5987 /passes/opt/opt_expr.cc | |
| parent | 08a226c9e728557f8b8c970a3a25b55ba5fc00cf (diff) | |
| download | yosys-9f0892159ebb88964839ea2cb5313ef1b87c624d.tar.gz yosys-9f0892159ebb88964839ea2cb5313ef1b87c624d.tar.bz2 yosys-9f0892159ebb88964839ea2cb5313ef1b87c624d.zip | |
flatten, techmap: don't canonicalize tpl driven bits via sigmap.
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.
Diffstat (limited to 'passes/opt/opt_expr.cc')
0 files changed, 0 insertions, 0 deletions
