aboutsummaryrefslogtreecommitdiffstats
path: root/testsuite/synth
diff options
context:
space:
mode:
authorTristan Gingold <tgingold@free.fr>2020-02-29 11:16:01 +0100
committerTristan Gingold <tgingold@free.fr>2020-02-29 11:16:01 +0100
commit3d2b4e54964242203e77cd0abfdc9c45c4cc3132 (patch)
tree015a8c6bc2002cc823fb791b03d330471edc5f67 /testsuite/synth
parent19b544a0b3a1e19dcba07a776c90d176d7dd8f6f (diff)
downloadghdl-3d2b4e54964242203e77cd0abfdc9c45c4cc3132.tar.gz
ghdl-3d2b4e54964242203e77cd0abfdc9c45c4cc3132.tar.bz2
ghdl-3d2b4e54964242203e77cd0abfdc9c45c4cc3132.zip
testsuite/synth: add a reproducer for tgingold/ghdlsynth-beta#87
Diffstat (limited to 'testsuite/synth')
-rw-r--r--testsuite/synth/synth87/repro01.vhdl23
-rw-r--r--testsuite/synth/synth87/tb_repro01.vhdl31
-rwxr-xr-xtestsuite/synth/synth87/testsuite.sh16
3 files changed, 70 insertions, 0 deletions
diff --git a/testsuite/synth/synth87/repro01.vhdl b/testsuite/synth/synth87/repro01.vhdl
new file mode 100644
index 000000000..82a04e722
--- /dev/null
+++ b/testsuite/synth/synth87/repro01.vhdl
@@ -0,0 +1,23 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity repro01 is
+ port (a, b, c : in std_logic;
+ z : out std_logic);
+end repro01;
+
+architecture behav of repro01 is
+ subtype logic is std_logic;
+
+ type my_rec is record
+ a : std_logic_vector(7 downto 0);
+ end record;
+ subtype my_rec2 is my_rec;
+begin
+ process(A, B, C)
+ variable temp : logic;
+ begin
+ temp := A and B;
+ Z <= temp or C;
+ end process;
+end behav;
diff --git a/testsuite/synth/synth87/tb_repro01.vhdl b/testsuite/synth/synth87/tb_repro01.vhdl
new file mode 100644
index 000000000..e12ecbaa2
--- /dev/null
+++ b/testsuite/synth/synth87/tb_repro01.vhdl
@@ -0,0 +1,31 @@
+entity tb_repro01 is
+end tb_repro01;
+
+library ieee;
+use ieee.std_logic_1164.all;
+
+architecture behav of tb_repro01 is
+ signal a : std_logic;
+ signal b : std_logic;
+ signal c : std_logic;
+ signal z : std_logic;
+begin
+ dut: entity work.repro01
+ port map (a, b, c, z);
+
+ process
+ constant av : std_logic_vector := b"1101";
+ constant bv : std_logic_vector := b"0111";
+ constant cv : std_logic_vector := b"0011";
+ constant zv : std_logic_vector := b"0111";
+ begin
+ for i in av'range loop
+ a <= av (i);
+ b <= bv (i);
+ c <= cv (i);
+ wait for 1 ns;
+ assert z = zv(i) severity failure;
+ end loop;
+ wait;
+ end process;
+end behav;
diff --git a/testsuite/synth/synth87/testsuite.sh b/testsuite/synth/synth87/testsuite.sh
new file mode 100755
index 000000000..0c9f3ac76
--- /dev/null
+++ b/testsuite/synth/synth87/testsuite.sh
@@ -0,0 +1,16 @@
+#! /bin/sh
+
+. ../../testenv.sh
+
+for t in repro01; do
+ analyze $t.vhdl tb_$t.vhdl
+ elab_simulate tb_$t
+ clean
+
+ synth $t.vhdl -e $t > syn_$t.vhdl
+ analyze syn_$t.vhdl tb_$t.vhdl
+ elab_simulate tb_$t --ieee-asserts=disable-at-0
+ clean
+done
+
+echo "Test successful"