From 5cfe481f7c2cbf90917b00862af02687f1ec2893 Mon Sep 17 00:00:00 2001 From: Tristan Gingold <tgingold@free.fr> Date: Thu, 26 Oct 2017 19:23:34 +0200 Subject: Add reproducer for #447. --- testsuite/gna/issue447/my_entity.vhdl | 38 +++++++++++++++++++++++++++++++++++ testsuite/gna/issue447/testsuite.sh | 10 +++++++++ 2 files changed, 48 insertions(+) create mode 100644 testsuite/gna/issue447/my_entity.vhdl create mode 100755 testsuite/gna/issue447/testsuite.sh (limited to 'testsuite/gna/issue447') 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" -- cgit v1.2.3