diff options
author | Eddie Hung <eddie@fpgeh.com> | 2019-08-28 12:36:06 -0700 |
---|---|---|
committer | GitHub <noreply@github.com> | 2019-08-28 12:36:06 -0700 |
commit | fc727fa5c9e0a04a5dc1b4fcef652c5bca90b220 (patch) | |
tree | e25fb147f2beeabab8a911ab487f34aed323f3e6 | |
parent | 9314a0a42ec05e82d2d3d77aebddfb06271a4730 (diff) | |
parent | c499dc3e73390c3bc9bf8045f2e4cad963c1fbad (diff) | |
download | yosys-fc727fa5c9e0a04a5dc1b4fcef652c5bca90b220.tar.gz yosys-fc727fa5c9e0a04a5dc1b4fcef652c5bca90b220.tar.bz2 yosys-fc727fa5c9e0a04a5dc1b4fcef652c5bca90b220.zip |
Merge pull request #1334 from YosysHQ/clifford/async2synclatch
Add $dlatch support to async2sync
-rw-r--r-- | passes/sat/async2sync.cc | 37 |
1 files changed, 36 insertions, 1 deletions
diff --git a/passes/sat/async2sync.cc b/passes/sat/async2sync.cc index d045d0dcb..24ae6e448 100644 --- a/passes/sat/async2sync.cc +++ b/passes/sat/async2sync.cc @@ -39,7 +39,7 @@ struct Async2syncPass : public Pass { log("reset value in the next cycle regardless of the data-in value at the time of\n"); log("the clock edge.\n"); log("\n"); - log("Currently only $adff and $dffsr cells are supported by this pass.\n"); + log("Currently only $adff, $dffsr, and $dlatch cells are supported by this pass.\n"); log("\n"); } void execute(std::vector<std::string> args, RTLIL::Design *design) YS_OVERRIDE @@ -169,6 +169,41 @@ struct Async2syncPass : public Pass { cell->type = "$dff"; continue; } + + if (cell->type.in("$dlatch")) + { + bool en_pol = cell->parameters["\\EN_POLARITY"].as_bool(); + + SigSpec sig_en = cell->getPort("\\EN"); + SigSpec sig_d = cell->getPort("\\D"); + SigSpec sig_q = cell->getPort("\\Q"); + + log("Replacing %s.%s (%s): EN=%s, D=%s, Q=%s\n", + log_id(module), log_id(cell), log_id(cell->type), + log_signal(sig_en), log_signal(sig_d), log_signal(sig_q)); + + Const init_val; + for (int i = 0; i < GetSize(sig_q); i++) { + SigBit bit = sigmap(sig_q[i]); + init_val.bits.push_back(initbits.count(bit) ? initbits.at(bit) : State::Sx); + del_initbits.insert(bit); + } + + Wire *new_q = module->addWire(NEW_ID, GetSize(sig_q)); + new_q->attributes["\\init"] = init_val; + + if (en_pol) { + module->addMux(NEW_ID, new_q, sig_d, sig_en, sig_q); + } else { + module->addMux(NEW_ID, sig_d, new_q, sig_en, sig_q); + } + + cell->setPort("\\Q", new_q); + cell->unsetPort("\\EN"); + cell->unsetParam("\\EN_POLARITY"); + cell->type = "$ff"; + continue; + } } for (auto wire : module->wires()) |