aboutsummaryrefslogtreecommitdiffstats
path: root/testsuite
diff options
context:
space:
mode:
authorTristan Gingold <tgingold@free.fr>2020-02-15 07:25:18 +0100
committerTristan Gingold <tgingold@free.fr>2020-02-15 07:25:18 +0100
commit81ff85ef4a5fd9d4ff7186a7a51f734e0c83e20a (patch)
treebbe7664001ab9eb7c63c1e0dc307f2656fc6dbe0 /testsuite
parent47da51fc0e2f0a96ca5744be3ce3d28fd7a44a4d (diff)
downloadghdl-81ff85ef4a5fd9d4ff7186a7a51f734e0c83e20a.tar.gz
ghdl-81ff85ef4a5fd9d4ff7186a7a51f734e0c83e20a.tar.bz2
ghdl-81ff85ef4a5fd9d4ff7186a7a51f734e0c83e20a.zip
testsuite/gna: add test from #1137
Diffstat (limited to 'testsuite')
-rw-r--r--testsuite/gna/issue1137/testbench.vhdl125
-rwxr-xr-xtestsuite/gna/issue1137/testsuite.sh11
-rw-r--r--testsuite/gna/issue1137/utestbench.vhdl125
3 files changed, 261 insertions, 0 deletions
diff --git a/testsuite/gna/issue1137/testbench.vhdl b/testsuite/gna/issue1137/testbench.vhdl
new file mode 100644
index 000000000..9b99f257f
--- /dev/null
+++ b/testsuite/gna/issue1137/testbench.vhdl
@@ -0,0 +1,125 @@
+
+library ieee;
+use ieee.std_logic_1164.all;
+use ieee.numeric_std.all;
+
+library std;
+use std.textio.all;
+
+entity testbench is
+end entity;
+
+architecture simu of testbench is
+
+ -- Dummy control
+ signal clk : std_logic := '0';
+ signal simu_clock_enable : std_logic := '1';
+
+ -- Dummy source signal
+ signal data_src : std_logic_vector(1 downto 0) := "00";
+ -- Three destination signals
+ signal data_dst1 : std_logic_vector(1 downto 0) := "11";
+ signal data_dst2 : std_logic_vector(1 downto 0) := "11";
+ signal data_dst3 : std_logic_vector(1 downto 0) := "11";
+ signal data_dst4 : std_logic_vector(1 downto 0) := "11";
+
+begin
+
+ -- Solution 1
+ -- THIS WORKS
+
+ process(all)
+ variable idx : integer;
+ begin
+
+ for c in 0 to 1 loop
+
+ idx := c;
+
+ data_dst1(idx) <= data_src(idx);
+
+ end loop;
+
+ end process;
+
+ -- Solution 2
+ -- FIXME THIS DOES NOT WORK, CREATES XXX
+
+ gen2 : for c in 0 to 1 generate
+
+ process(all)
+ variable idx : integer;
+ begin
+
+ idx := c;
+
+ data_dst2(idx) <= data_src(idx);
+
+ end process;
+
+ end generate;
+
+ -- Solution 4
+ -- THIS WORKS
+
+ gen4 : for c in 0 to 1 generate
+
+ process(all)
+ constant idx : integer := c;
+ begin
+
+ data_dst4(idx) <= data_src(idx);
+
+ end process;
+
+ end generate;
+
+ -- Solution 3
+ -- THIS WORKS
+
+ gen3 : for c in 0 to 1 generate
+
+ constant idx : integer := c;
+
+ begin
+
+ data_dst3(idx) <= data_src(idx);
+
+ end generate;
+
+ -- Dummy clock generation
+
+ clk <= (not clk) and simu_clock_enable after 5 ns;
+
+ -- Main testbench process
+
+ process
+ -- To print simulation messages
+ variable l : line;
+ begin
+
+ wait until rising_edge(clk);
+ wait until rising_edge(clk);
+
+ write(l, string'("Result 1 : "));
+ write(l, to_string(data_dst1));
+ writeline(output, l);
+
+ write(l, string'("Result 2 : "));
+ write(l, to_string(data_dst2));
+ writeline(output, l);
+
+ write(l, string'("Result 3 : "));
+ write(l, to_string(data_dst3));
+ writeline(output, l);
+
+ write(l, string'("Result 4 : "));
+ write(l, to_string(data_dst4));
+ writeline(output, l);
+
+ simu_clock_enable <= '0';
+
+ end process;
+
+end architecture;
+
diff --git a/testsuite/gna/issue1137/testsuite.sh b/testsuite/gna/issue1137/testsuite.sh
new file mode 100755
index 000000000..1401b0901
--- /dev/null
+++ b/testsuite/gna/issue1137/testsuite.sh
@@ -0,0 +1,11 @@
+#! /bin/sh
+
+. ../../testenv.sh
+
+export GHDL_STD_FLAGS=--std=08
+analyze testbench.vhdl
+elab_simulate testbench
+
+clean
+
+echo "Test successful"
diff --git a/testsuite/gna/issue1137/utestbench.vhdl b/testsuite/gna/issue1137/utestbench.vhdl
new file mode 100644
index 000000000..ba55de262
--- /dev/null
+++ b/testsuite/gna/issue1137/utestbench.vhdl
@@ -0,0 +1,125 @@
+
+library ieee;
+use ieee.std_logic_1164.all;
+use ieee.numeric_std.all;
+
+library std;
+use std.textio.all;
+
+entity testbench is
+end entity;
+
+architecture simu of testbench is
+
+ -- Dummy control
+ signal clk : std_ulogic := '0';
+ signal simu_clock_enable : std_ulogic := '1';
+
+ -- Dummy source signal
+ signal data_src : std_ulogic_vector(1 downto 0) := "00";
+ -- Three destination signals
+ signal data_dst1 : std_ulogic_vector(1 downto 0) := "11";
+ signal data_dst2 : std_ulogic_vector(1 downto 0) := "11";
+ signal data_dst3 : std_ulogic_vector(1 downto 0) := "11";
+ signal data_dst4 : std_ulogic_vector(1 downto 0) := "11";
+
+begin
+
+ -- Solution 1
+ -- THIS WORKS
+
+ process(all)
+ variable idx : integer;
+ begin
+
+ for c in 0 to 1 loop
+
+ idx := c;
+
+ data_dst1(idx) <= data_src(idx);
+
+ end loop;
+
+ end process;
+
+ -- Solution 2
+ -- FIXME THIS DOES NOT WORK, CREATES XXX
+
+ gen2 : for c in 0 to 1 generate
+
+ process(all)
+ variable idx : integer;
+ begin
+
+ idx := c;
+
+ data_dst2(idx) <= data_src(idx);
+
+ end process;
+
+ end generate;
+
+ -- Solution 4
+ -- THIS WORKS
+
+ gen4 : for c in 0 to 1 generate
+
+ process(all)
+ constant idx : integer := c;
+ begin
+
+ data_dst4(idx) <= data_src(idx);
+
+ end process;
+
+ end generate;
+
+ -- Solution 3
+ -- THIS WORKS
+
+ gen3 : for c in 0 to 1 generate
+
+ constant idx : integer := c;
+
+ begin
+
+ data_dst3(idx) <= data_src(idx);
+
+ end generate;
+
+ -- Dummy clock generation
+
+ clk <= (not clk) and simu_clock_enable after 5 ns;
+
+ -- Main testbench process
+
+ process
+ -- To print simulation messages
+ variable l : line;
+ begin
+
+ wait until rising_edge(clk);
+ wait until rising_edge(clk);
+
+ write(l, string'("Result 1 : "));
+ write(l, to_string(data_dst1));
+ writeline(output, l);
+
+ write(l, string'("Result 2 : "));
+ write(l, to_string(data_dst2));
+ writeline(output, l);
+
+ write(l, string'("Result 3 : "));
+ write(l, to_string(data_dst3));
+ writeline(output, l);
+
+ write(l, string'("Result 4 : "));
+ write(l, to_string(data_dst4));
+ writeline(output, l);
+
+ simu_clock_enable <= '0';
+
+ end process;
+
+end architecture;
+