diff options
| author | Eddie Hung <eddie@fpgeh.com> | 2019-05-30 01:23:36 -0700 | 
|---|---|---|
| committer | Eddie Hung <eddie@fpgeh.com> | 2019-05-30 01:23:36 -0700 | 
| commit | fdfc18be91123e2939f134dafc12e1e0c1a82f7b (patch) | |
| tree | f5feea08b0bc644a5474f333944eaea1f78d9ee1 /frontends | |
| parent | 8c58c728a79954603289abf3520139da0a9bbb26 (diff) | |
| download | yosys-fdfc18be91123e2939f134dafc12e1e0c1a82f7b.tar.gz yosys-fdfc18be91123e2939f134dafc12e1e0c1a82f7b.tar.bz2 yosys-fdfc18be91123e2939f134dafc12e1e0c1a82f7b.zip | |
Carry in/out to be the last input/output for chains to be preserved
Diffstat (limited to 'frontends')
| -rw-r--r-- | frontends/aiger/aigerparse.cc | 38 | 
1 files changed, 38 insertions, 0 deletions
| diff --git a/frontends/aiger/aigerparse.cc b/frontends/aiger/aigerparse.cc index 8d7588f88..915c53a1b 100644 --- a/frontends/aiger/aigerparse.cc +++ b/frontends/aiger/aigerparse.cc @@ -549,6 +549,7 @@ void AigerReader::post_process()          std::string type, symbol;          int variable, index;          int pi_count = 0, ci_count = 0, co_count = 0; +        pool<RTLIL::Module*> abc_carry_modules;          while (mf >> type >> variable >> index >> symbol) {              RTLIL::IdString escaped_s = RTLIL::escape_id(symbol);              if (type == "input") { @@ -646,6 +647,43 @@ void AigerReader::post_process()                      module->rename(cell, escaped_s);                      RTLIL::Module* box_module = design->module(cell->type);                      log_assert(box_module); + +                    if (box_module->attributes.count("\\abc_carry") && !abc_carry_modules.count(box_module)) { +                        RTLIL::Wire* carry_in = nullptr, *carry_out = nullptr; +                        RTLIL::Wire* last_in = nullptr, *last_out = nullptr; +                        for (const auto &port_name : box_module->ports) { +                            RTLIL::Wire* w = box_module->wire(port_name); +                            log_assert(w); +                            if (w->port_input) { +                                if (w->attributes.count("\\abc_carry_in")) { +                                    log_assert(!carry_in); +                                    carry_in = w; +                                } +                                log_assert(!last_in || last_in->port_id < w->port_id); +                                last_in = w; +                            } +                            if (w->port_output) { +                                if (w->attributes.count("\\abc_carry_out")) { +                                    log_assert(!carry_out); +                                    carry_out = w; +                                } +                                log_assert(!last_out || last_out->port_id < w->port_id); +                                last_out = w; +                            } +                        } + +                        if (carry_in != last_in) { +                            std::swap(box_module->ports[carry_in->port_id], box_module->ports[last_in->port_id]); +                            std::swap(carry_in->port_id, last_in->port_id); +                        } +                        if (carry_out != last_out) { +                            log_assert(last_out); +                            std::swap(box_module->ports[carry_out->port_id], box_module->ports[last_out->port_id]); +                            std::swap(carry_out->port_id, last_out->port_id); +                        } +                    } + +                      // NB: Assume box_module->ports are sorted alphabetically                      //     (as RTLIL::Module::fixup_ports() would do)                      for (auto port_name : box_module->ports) { | 
