diff options
author | Tristan Gingold <tgingold@free.fr> | 2017-10-26 19:23:34 +0200 |
---|---|---|
committer | Tristan Gingold <tgingold@free.fr> | 2017-10-26 19:23:34 +0200 |
commit | 5cfe481f7c2cbf90917b00862af02687f1ec2893 (patch) | |
tree | b7544ec471fde2f522f98bdca6ceab45313323c7 /testsuite/gna | |
parent | 254b3b89d28d1fa7a46aa83567e8bb5bb5481b0a (diff) | |
download | ghdl-5cfe481f7c2cbf90917b00862af02687f1ec2893.tar.gz ghdl-5cfe481f7c2cbf90917b00862af02687f1ec2893.tar.bz2 ghdl-5cfe481f7c2cbf90917b00862af02687f1ec2893.zip |
Add reproducer for #447.
Diffstat (limited to 'testsuite/gna')
-rw-r--r-- | testsuite/gna/issue447/my_entity.vhdl | 38 | ||||
-rwxr-xr-x | testsuite/gna/issue447/testsuite.sh | 10 |
2 files changed, 48 insertions, 0 deletions
diff --git a/testsuite/gna/issue447/my_entity.vhdl b/testsuite/gna/issue447/my_entity.vhdl new file mode 100644 index 000000000..f1c6004c6 --- /dev/null +++ b/testsuite/gna/issue447/my_entity.vhdl @@ -0,0 +1,38 @@ +library ieee; +use ieee.std_logic_1164.all; +use ieee.numeric_std.all; + + +entity my_entity is + generic ( + GEN: std_ulogic_vector := b"1111" + ); + port ( + clk: in std_ulogic; + a: in std_ulogic_vector(7 downto 0); + b: out std_ulogic_vector(7 downto 0) + ); +end; + +architecture behavioral of my_entity is + + alias GEN_DOWNTO: std_ulogic_vector(GEN'length - 1 downto 0) is GEN; + + function foo(x: std_ulogic_vector(7 downto 0)) + return std_ulogic_vector is + variable ret: std_ulogic_vector(7 downto 0); + begin + ret := x; + for i in natural(GEN_DOWNTO'length - 1) downto 0 loop + ret(i) := GEN_DOWNTO(i) and x(i); + end loop; + return ret; + end; + +begin + process (clk) begin + if rising_edge(clk) then + b <= foo(a); + end if; + end process; +end; diff --git a/testsuite/gna/issue447/testsuite.sh b/testsuite/gna/issue447/testsuite.sh new file mode 100755 index 000000000..4fef43784 --- /dev/null +++ b/testsuite/gna/issue447/testsuite.sh @@ -0,0 +1,10 @@ +#! /bin/sh + +. ../../testenv.sh + +export GHDL_STD_FLAGS=--std=93 +analyze my_entity.vhdl + +clean + +echo "Test successful" |