diff options
author | Eddie Hung <eddie@fpgeh.com> | 2020-02-12 15:25:30 -0800 |
---|---|---|
committer | Eddie Hung <eddie@fpgeh.com> | 2020-02-27 10:17:29 -0800 |
commit | 12d70ca8fbad73f2615e711e786f8b90fa005bee (patch) | |
tree | 6459527e212b6e0ac65d99ad023606b6afd5e9f4 /passes | |
parent | 46a89d7264f597be9ad10390fa44c22e16538548 (diff) | |
download | yosys-12d70ca8fbad73f2615e711e786f8b90fa005bee.tar.gz yosys-12d70ca8fbad73f2615e711e786f8b90fa005bee.tar.bz2 yosys-12d70ca8fbad73f2615e711e786f8b90fa005bee.zip |
xilinx: improve specify functionality
Diffstat (limited to 'passes')
-rw-r--r-- | passes/techmap/abc9_ops.cc | 38 |
1 files changed, 19 insertions, 19 deletions
diff --git a/passes/techmap/abc9_ops.cc b/passes/techmap/abc9_ops.cc index 9abe6af9f..c48cd5c86 100644 --- a/passes/techmap/abc9_ops.cc +++ b/passes/techmap/abc9_ops.cc @@ -380,8 +380,10 @@ void prep_xaiger(RTLIL::Module *module, bool dff) void prep_delays(RTLIL::Design *design) { - // Derive and collect all blackbox modules, and collect all blackbox instantiations - pool<Module*> derived; + // Derive and collect all Yosys blackbox modules that are not combinatorial abc9 boxes + // (e.g. DSPs, RAMs, etc.) nor abc9 flops and collect all such instantiations + pool<Module*> blackboxes; + pool<Module*> flops; std::vector<Cell*> cells; for (auto module : design->selected_modules()) { if (module->processes.size() > 0) { @@ -400,42 +402,38 @@ void prep_delays(RTLIL::Design *design) continue; if (inst_module->attributes.count(ID(abc9_box))) continue; - IdString derived_type = inst_module->derive(design, cell->parameters); - inst_module = design->module(derived_type); + IdString blackboxes_type = inst_module->derive(design, cell->parameters); + inst_module = design->module(blackboxes_type); log_assert(inst_module); - derived.insert(inst_module); + blackboxes.insert(inst_module); + + if (inst_module->get_bool_attribute(ID(abc9_flop))) { + flops.insert(inst_module); + continue; // do not add $__ABC9_DELAY boxes to flops + // as delays will be captured in the flop box + } cells.emplace_back(cell); } } // Transform all $specify3 and $specrule to abc9_{arrival,required} attributes - std::vector<Module*> flops; dict<SigBit, int> arrivals, requireds; pool<Wire*> ports; std::stringstream ss; - for (auto module : derived) { - if (module->get_bool_attribute(ID(abc9_flop))) - flops.push_back(module); - + for (auto module : blackboxes) { arrivals.clear(); requireds.clear(); for (auto cell : module->cells()) { if (cell->type == ID($specify3)) { auto src = cell->getPort(ID(SRC)); - auto dat = cell->getPort(ID(DAT)); auto dst = cell->getPort(ID(DST)); for (const auto &c : src.chunks()) if (!c.wire->port_input) log_error("Module '%s' contains specify cell '%s' where SRC '%s' is not a module input.\n", log_id(module), log_id(cell), log_signal(src)); - for (const auto &c : dat.chunks()) - if (!c.wire->port_input) - log_error("Module '%s' contains specify cell '%s' where DAT '%s' is not a module input.\n", log_id(module), log_id(cell), log_signal(dat)); for (const auto &c : dst.chunks()) if (!c.wire->port_output) log_error("Module '%s' contains specify cell '%s' where DST '%s' is not a module output.\n", log_id(module), log_id(cell), log_signal(dst)); - if (!cell->getParam(ID(EDGE_EN)).as_bool()) - continue; int rise_max = cell->getParam(ID(T_RISE_MAX)).as_int(); int fall_max = cell->getParam(ID(T_FALL_MAX)).as_int(); int max = std::max(rise_max,fall_max); @@ -443,7 +441,7 @@ void prep_delays(RTLIL::Design *design) log_warning("Module '%s' contains specify cell '%s' with T_{RISE,FALL}_MAX < 0 which is currently unsupported. Ignoring.\n", log_id(module), log_id(cell)); continue; } - for (auto d : dst) + for (const auto &d : dst) arrivals[d] = std::max(arrivals[d], max); } else if (cell->type == ID($specrule)) { @@ -472,8 +470,10 @@ void prep_delays(RTLIL::Design *design) continue; ports.clear(); - for (const auto &i : arrivals) + for (const auto &i : arrivals) { + log_dump(i.first, i.first.wire->name); ports.insert(i.first.wire); + } for (auto wire : ports) { log_assert(wire->port_output); ss.str(""); @@ -1239,7 +1239,7 @@ struct Abc9OpsPass : public Pass { log("\n"); log(" -prep_box\n"); log(" pre-compute the box library by analysing all modules marked with\n"); - log(" (* abc9_box *)\n"); + log(" (* abc9_box *).\n"); log("\n"); log(" -write_box <dst>\n"); log(" write the pre-computed box library to <dst>.\n"); |