aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMiodrag Milanovic <mmicko@gmail.com>2019-10-04 11:08:42 +0200
committerMiodrag Milanovic <mmicko@gmail.com>2019-10-04 11:08:42 +0200
commita5844e3ceb76152d1e87ad8fdf1c71553238ef64 (patch)
treed7bffd64e48ccc98b725af9fe7ce3f676c61ef99
parent3238ee7d354aed51eb61ce5a8c2799f56f2cb4b2 (diff)
downloadyosys-a5844e3ceb76152d1e87ad8fdf1c71553238ef64.tar.gz
yosys-a5844e3ceb76152d1e87ad8fdf1c71553238ef64.tar.bz2
yosys-a5844e3ceb76152d1e87ad8fdf1c71553238ef64.zip
split latches into separate checks
-rw-r--r--tests/anlogic/latches.v34
-rw-r--r--tests/anlogic/latches.ys31
2 files changed, 24 insertions, 41 deletions
diff --git a/tests/anlogic/latches.v b/tests/anlogic/latches.v
index 9dc43e4c2..adb5d5319 100644
--- a/tests/anlogic/latches.v
+++ b/tests/anlogic/latches.v
@@ -22,37 +22,3 @@ module latchsr
else if ( en )
q <= d;
endmodule
-
-
-module top (
-input clk,
-input clr,
-input pre,
-input a,
-output b,b1,b2
-);
-
-
-latchp u_latchp (
- .en (clk ),
- .d (a ),
- .q (b )
- );
-
-
-latchn u_latchn (
- .en (clk ),
- .d (a ),
- .q (b1 )
- );
-
-
-latchsr u_latchsr (
- .en (clk ),
- .clr (clr),
- .pre (pre),
- .d (a ),
- .q (b2 )
- );
-
-endmodule
diff --git a/tests/anlogic/latches.ys b/tests/anlogic/latches.ys
index b5e52cf16..ae9e15ff8 100644
--- a/tests/anlogic/latches.ys
+++ b/tests/anlogic/latches.ys
@@ -2,15 +2,32 @@ read_verilog latches.v
design -save read
proc
-async2sync # converts latches to a 'sync' variant clocked by a 'super'-clock
-flatten
+hierarchy -top latchp
+# Can't run any sort of equivalence check because latches are blown to LUTs
synth_anlogic
-equiv_opt -assert -map +/anlogic/cells_sim.v synth_anlogic # equivalency check
-design -load postopt # load the post-opt design (otherwise equiv_opt loads the pre-opt design)
+cd latchp # Constrain all select calls below inside the top module
+select -assert-count 1 t:AL_MAP_LUT3
+
+select -assert-none t:AL_MAP_LUT3 %% t:* %D
+
+
+design -load read
+proc
+hierarchy -top latchn
+# Can't run any sort of equivalence check because latches are blown to LUTs
+synth_anlogic
+cd latchn # Constrain all select calls below inside the top module
+select -assert-count 1 t:AL_MAP_LUT3
+
+select -assert-none t:AL_MAP_LUT3 %% t:* %D
+
design -load read
+proc
+hierarchy -top latchsr
+# Can't run any sort of equivalence check because latches are blown to LUTs
synth_anlogic
-cd top
-select -assert-count 2 t:AL_MAP_LUT3
+cd latchsr # Constrain all select calls below inside the top module
select -assert-count 1 t:AL_MAP_LUT5
-select -assert-none t:AL_MAP_LUT3 t:AL_MAP_LUT5 %% t:* %D
+
+select -assert-none t:AL_MAP_LUT5 %% t:* %D