diff options
-rw-r--r-- | testsuite/gna/ticket94/apkg.vhd | 10 | ||||
-rw-r--r-- | testsuite/gna/ticket94/asrc.vhd | 14 | ||||
-rw-r--r-- | testsuite/gna/ticket94/build.sh | 10 | ||||
-rw-r--r-- | testsuite/gna/ticket94/tb.vhd | 49 | ||||
-rw-r--r-- | testsuite/gna/ticket94/tb1.vhd | 32 | ||||
-rw-r--r-- | testsuite/gna/ticket94/tb2.vhd | 29 | ||||
-rw-r--r-- | testsuite/gna/ticket94/tb3.vhd | 28 | ||||
-rw-r--r-- | testsuite/gna/ticket94/tb4.vhd | 31 | ||||
-rwxr-xr-x | testsuite/gna/ticket94/testsuite.sh | 45 |
9 files changed, 248 insertions, 0 deletions
diff --git a/testsuite/gna/ticket94/apkg.vhd b/testsuite/gna/ticket94/apkg.vhd new file mode 100644 index 0000000..09eba95 --- /dev/null +++ b/testsuite/gna/ticket94/apkg.vhd @@ -0,0 +1,10 @@ +library ieee; +use ieee.std_logic_1164.all; + +package apkg is + + component acomp is + port (x: in std_ulogic; y: out std_ulogic); + end component; + +end apkg; diff --git a/testsuite/gna/ticket94/asrc.vhd b/testsuite/gna/ticket94/asrc.vhd new file mode 100644 index 0000000..d65c812 --- /dev/null +++ b/testsuite/gna/ticket94/asrc.vhd @@ -0,0 +1,14 @@ + +library ieee; +use ieee.std_logic_1164.all; + +entity acomp is + port (x: in std_ulogic; y: out std_ulogic); +end entity; + +architecture aarch of acomp is +begin + + y <= x; + +end architecture; diff --git a/testsuite/gna/ticket94/build.sh b/testsuite/gna/ticket94/build.sh new file mode 100644 index 0000000..a5bf675 --- /dev/null +++ b/testsuite/gna/ticket94/build.sh @@ -0,0 +1,10 @@ +#!/bin/sh + +set -e + +cmd() { echo "$*" ; $* ; } + +GHDL=${GHDL:-ghdl} +cmd $GHDL -a --work=alib asrc.vhd +cmd $GHDL -a tb.vhd +cmd $GHDL -e tb diff --git a/testsuite/gna/ticket94/tb.vhd b/testsuite/gna/ticket94/tb.vhd new file mode 100644 index 0000000..313d59c --- /dev/null +++ b/testsuite/gna/ticket94/tb.vhd @@ -0,0 +1,49 @@ + +library ieee; +use ieee.std_logic_1164.all; +library alib; +use alib.acomp; + +entity tb is + +end; + +architecture arch of tb is + + signal clk: std_logic := '0'; + signal lclk: std_ulogic; + + signal stop: boolean := false; + signal lclk_count: integer := 0; + + component acomp is + port (x: in std_ulogic; y: out std_ulogic); + end component; + +begin + + clk <= not clk after 10 ns when (not stop) else '0'; + + ainst: acomp + port map (clk, lclk); + + process (lclk) is + begin + if rising_edge(lclk) then + lclk_count <= lclk_count + 1; + end if; + end process; + + process is + begin + report "start test"; + wait for 1 ms; + report "end test"; + report "lclk_count = " & integer'image(lclk_count); + assert lclk_count > 20000 report "test failed"; + if lclk_count > 20000 then report "test passed"; end if; + stop <= true; + wait; + end process; + +end architecture; diff --git a/testsuite/gna/ticket94/tb1.vhd b/testsuite/gna/ticket94/tb1.vhd new file mode 100644 index 0000000..b0b901c --- /dev/null +++ b/testsuite/gna/ticket94/tb1.vhd @@ -0,0 +1,32 @@ + +library ieee; +use ieee.std_logic_1164.all; +library alib; +use alib.acomp; + +entity tb1 is +end; + +architecture arch of tb1 is + + signal a, b : std_logic := '0'; + component acomp is + port (x: in std_ulogic; y: out std_ulogic); + end component; + +begin + ainst: acomp + port map (a, b); + + process is + begin + a <= '0'; + wait for 1 ns; + assert b = '0' report "component is missing" severity failure; + a <= '1'; + wait for 1 ns; + assert b = '1' report "component is missing" severity failure; + wait; + end process; + +end architecture; diff --git a/testsuite/gna/ticket94/tb2.vhd b/testsuite/gna/ticket94/tb2.vhd new file mode 100644 index 0000000..0c52aa1 --- /dev/null +++ b/testsuite/gna/ticket94/tb2.vhd @@ -0,0 +1,29 @@ + +library ieee; +use ieee.std_logic_1164.all; +library alib; +use alib.acomp; + +entity tb2 is +end; + +architecture arch of tb2 is + + signal a, b : std_logic := '0'; + +begin + ainst: alib.apkg.acomp + port map (a, b); + + process is + begin + a <= '0'; + wait for 1 ns; + assert b = '0' report "component is missing" severity failure; + a <= '1'; + wait for 1 ns; + assert b = '1' report "component is missing" severity failure; + wait; + end process; + +end architecture; diff --git a/testsuite/gna/ticket94/tb3.vhd b/testsuite/gna/ticket94/tb3.vhd new file mode 100644 index 0000000..9cef08e --- /dev/null +++ b/testsuite/gna/ticket94/tb3.vhd @@ -0,0 +1,28 @@ + +library ieee; +use ieee.std_logic_1164.all; +library alib; + +entity tb3 is +end; + +architecture arch of tb3 is + + signal a, b : std_logic := '0'; + +begin + ainst: alib.apkg.acomp + port map (a, b); + + process is + begin + a <= '0'; + wait for 1 ns; + assert b = '0' report "component is missing" severity failure; + a <= '1'; + wait for 1 ns; + assert b = '1' report "component is missing" severity failure; + wait; + end process; + +end architecture; diff --git a/testsuite/gna/ticket94/tb4.vhd b/testsuite/gna/ticket94/tb4.vhd new file mode 100644 index 0000000..d981701 --- /dev/null +++ b/testsuite/gna/ticket94/tb4.vhd @@ -0,0 +1,31 @@ + +library ieee; +use ieee.std_logic_1164.all; +library alib; + +entity tb4 is +end; + +architecture arch of tb4 is + + signal a, b : std_logic := '0'; + component acomp is + port (x: in std_ulogic; y: out std_ulogic); + end component; + +begin + ainst: acomp + port map (a, b); + + process is + begin + a <= '0'; + wait for 1 ns; + assert b = '0' report "component is missing" severity failure; + a <= '1'; + wait for 1 ns; + assert b = '1' report "component is missing" severity failure; + wait; + end process; + +end architecture; diff --git a/testsuite/gna/ticket94/testsuite.sh b/testsuite/gna/ticket94/testsuite.sh new file mode 100755 index 0000000..796dd69 --- /dev/null +++ b/testsuite/gna/ticket94/testsuite.sh @@ -0,0 +1,45 @@ +#! /bin/sh + +. ../../testenv.sh + +# Original test +analyze --work=alib asrc.vhd +analyze tb.vhd +elab_simulate tb + +# Reproducer - entity would be visible in the absence of the component +analyze tb1.vhd +elab_simulate tb1 + +# Reproducer - entity is directly visible +analyze --work=alib apkg.vhd +analyze tb2.vhd +elab_simulate tb2 + +# Reproducer - entity is in the same library. (93c) +analyze tb3.vhd +elab_simulate tb3 + +# Reproducer - entity in a different library, not visible. +analyze tb4.vhd +elab_simulate_failure tb4 +elab_simulate --syn-binding tb4 + +clean +clean alib + +# Reproducer - entity is in the same library (93) +GHDL_STD_FLAGS=--std=93 + +analyze --work=alib asrc.vhd +analyze --work=alib apkg.vhd +analyze tb3.vhd +elab_simulate_failure tb3 + +# But still works with --syn-binding +elab_simulate --syn-binding tb3 + +clean +clean alib + +echo "Test successful" |