aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMarcelina Koƛcielnicka <mwk@0x04.net>2021-03-06 03:59:03 +0100
committerMarcelina Koƛcielnicka <mwk@0x04.net>2021-03-08 17:01:43 +0100
commit760284033d6f255790d44bfcda0d1625a0c7bc87 (patch)
treee23050e2e3c0c85fd560d0f63dca347832d8e24f
parentbc717abad2187b2aacaac7e9b8e152462769056a (diff)
downloadyosys-760284033d6f255790d44bfcda0d1625a0c7bc87.tar.gz
yosys-760284033d6f255790d44bfcda0d1625a0c7bc87.tar.bz2
yosys-760284033d6f255790d44bfcda0d1625a0c7bc87.zip
proc_dff: Fix emitted FF when a register is not assigned in async reset
Fixes #2619.
-rw-r--r--passes/proc/proc_dff.cc4
-rw-r--r--tests/proc/bug2619.ys23
2 files changed, 27 insertions, 0 deletions
diff --git a/passes/proc/proc_dff.cc b/passes/proc/proc_dff.cc
index e320a72a6..2b6ca8449 100644
--- a/passes/proc/proc_dff.cc
+++ b/passes/proc/proc_dff.cc
@@ -328,6 +328,10 @@ void proc_dff(RTLIL::Module *mod, RTLIL::Process *proc, ConstEval &ce)
ce.assign_map.apply(sig);
if (rstval == sig) {
+ if (sync_level->type == RTLIL::SyncType::ST1)
+ insig = mod->Mux(NEW_ID, insig, sig, sync_level->signal);
+ else
+ insig = mod->Mux(NEW_ID, sig, insig, sync_level->signal);
rstval = RTLIL::SigSpec(RTLIL::State::Sz, sig.size());
sync_level = NULL;
}
diff --git a/tests/proc/bug2619.ys b/tests/proc/bug2619.ys
new file mode 100644
index 000000000..a080b94f5
--- /dev/null
+++ b/tests/proc/bug2619.ys
@@ -0,0 +1,23 @@
+read_verilog << EOT
+
+module top(...);
+
+input D1, D2, R, CLK;
+output reg Q1, Q2;
+
+always @(posedge CLK, posedge R) begin
+ Q1 <= 0;
+ if (!R) begin
+ Q1 <= D1;
+ Q2 <= D2;
+ end
+end
+
+endmodule
+
+EOT
+
+proc
+opt
+select -assert-count 1 t:$adff
+select -assert-count 1 t:$dffe