diff options
author | Eddie Hung <eddie@fpgeh.com> | 2020-01-05 10:20:24 -0800 |
---|---|---|
committer | Eddie Hung <eddie@fpgeh.com> | 2020-01-05 10:20:24 -0800 |
commit | b5f60e055d07579a2d4f23fc053ca030f103f377 (patch) | |
tree | 2a32b253a9a004c47b0e61ca0449a4e93eff40d4 /passes/techmap/abc9_map.cc | |
parent | 8293a3fe749701c7df425acd81e24a2a34f5032e (diff) | |
download | yosys-b5f60e055d07579a2d4f23fc053ca030f103f377.tar.gz yosys-b5f60e055d07579a2d4f23fc053ca030f103f377.tar.bz2 yosys-b5f60e055d07579a2d4f23fc053ca030f103f377.zip |
write_xaiger to pad, not abc9_ops -prep_holes
Diffstat (limited to 'passes/techmap/abc9_map.cc')
-rw-r--r-- | passes/techmap/abc9_map.cc | 13 |
1 files changed, 4 insertions, 9 deletions
diff --git a/passes/techmap/abc9_map.cc b/passes/techmap/abc9_map.cc index b3642ab22..e061cadeb 100644 --- a/passes/techmap/abc9_map.cc +++ b/passes/techmap/abc9_map.cc @@ -445,24 +445,19 @@ void abc9_module(RTLIL::Design *design, RTLIL::Module *module, std::string scrip if (existing_cell) { cell->parameters = existing_cell->parameters; cell->attributes = existing_cell->attributes; + if (cell->attributes.erase("\\abc9_box_seq")) { + module->swap_names(cell, existing_cell); + module->remove(existing_cell); + } } else { cell->parameters = mapped_cell->parameters; cell->attributes = mapped_cell->attributes; } - auto abc9_box = cell->attributes.erase("\\abc9_box_seq"); - if (abc9_box) { - module->swap_names(cell, existing_cell); - module->remove(existing_cell); - } RTLIL::Module* box_module = design->module(mapped_cell->type); auto abc9_flop = box_module && box_module->attributes.count("\\abc9_flop"); for (auto &conn : mapped_cell->connections()) { - // Skip entire box ports composed entirely of padding only - if (abc9_box && conn.second.is_wire() && conn.second.as_wire()->get_bool_attribute(ID(abc9_padding))) - continue; - RTLIL::SigSpec newsig; for (auto c : conn.second.chunks()) { if (c.width == 0) |