mirror of
https://github.com/YosysHQ/yosys
synced 2026-06-12 03:45:42 +00:00
fixup! async2sync: $dffsr has undef output on S&R
This commit is contained in:
parent
85013f9ed3
commit
43ef4d2901
1 changed files with 4 additions and 4 deletions
|
|
@ -160,26 +160,26 @@ struct Async2syncPass : public Pass {
|
||||||
SigSpec sig_clr_inv = ff.sig_clr;
|
SigSpec sig_clr_inv = ff.sig_clr;
|
||||||
|
|
||||||
if (!ff.pol_set) {
|
if (!ff.pol_set) {
|
||||||
if (!ff.is_fine || sig_set.size() > 1)
|
if (!ff.is_fine)
|
||||||
sig_set = module->Not(NEW_ID, sig_set);
|
sig_set = module->Not(NEW_ID, sig_set);
|
||||||
else
|
else
|
||||||
sig_set = module->NotGate(NEW_ID, sig_set);
|
sig_set = module->NotGate(NEW_ID, sig_set);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ff.pol_clr) {
|
if (ff.pol_clr) {
|
||||||
if (!ff.is_fine || sig_clr.size() > 1)
|
if (!ff.is_fine)
|
||||||
sig_clr_inv = module->Not(NEW_ID, sig_clr);
|
sig_clr_inv = module->Not(NEW_ID, sig_clr);
|
||||||
else
|
else
|
||||||
sig_clr_inv = module->NotGate(NEW_ID, sig_clr);
|
sig_clr_inv = module->NotGate(NEW_ID, sig_clr);
|
||||||
} else {
|
} else {
|
||||||
if (!ff.is_fine || sig_clr.size() > 1)
|
if (!ff.is_fine)
|
||||||
sig_clr = module->Not(NEW_ID, sig_clr);
|
sig_clr = module->Not(NEW_ID, sig_clr);
|
||||||
else
|
else
|
||||||
sig_clr = module->NotGate(NEW_ID, sig_clr);
|
sig_clr = module->NotGate(NEW_ID, sig_clr);
|
||||||
}
|
}
|
||||||
|
|
||||||
SigSpec set_and_clr;
|
SigSpec set_and_clr;
|
||||||
if (!ff.is_fine || sig_clr.size() > 1 || sig_set.size() > 1)
|
if (!ff.is_fine)
|
||||||
set_and_clr = module->And(NEW_ID, sig_set, sig_clr);
|
set_and_clr = module->And(NEW_ID, sig_set, sig_clr);
|
||||||
else
|
else
|
||||||
set_and_clr = module->AndGate(NEW_ID, sig_set, sig_clr);
|
set_and_clr = module->AndGate(NEW_ID, sig_set, sig_clr);
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue