From dcf9335a06eb78c5d977945f713f326e6288ae9a Mon Sep 17 00:00:00 2001 From: Tristan Gingold Date: Sat, 10 Jan 2015 16:06:11 +0100 Subject: File bug23165. --- testsuite/gna/bug23165/mwe_failing/counter.vhd | 33 +++++++++++++++++++ testsuite/gna/bug23165/mwe_failing/mwe.vhd | 40 +++++++++++++++++++++++ testsuite/gna/bug23165/mwe_working/counter.vhd | 33 +++++++++++++++++++ testsuite/gna/bug23165/mwe_working/mwe.vhd | 45 ++++++++++++++++++++++++++ testsuite/gna/bug23165/testsuite.sh | 15 +++++++++ 5 files changed, 166 insertions(+) create mode 100644 testsuite/gna/bug23165/mwe_failing/counter.vhd create mode 100644 testsuite/gna/bug23165/mwe_failing/mwe.vhd create mode 100644 testsuite/gna/bug23165/mwe_working/counter.vhd create mode 100644 testsuite/gna/bug23165/mwe_working/mwe.vhd create mode 100755 testsuite/gna/bug23165/testsuite.sh diff --git a/testsuite/gna/bug23165/mwe_failing/counter.vhd b/testsuite/gna/bug23165/mwe_failing/counter.vhd new file mode 100644 index 000000000..9982f1d6c --- /dev/null +++ b/testsuite/gna/bug23165/mwe_failing/counter.vhd @@ -0,0 +1,33 @@ +-- counter +-- clk: clock input +-- en: enable input +-- rst: reset input +-- dir: direction pin (1 = up, 0 = down) +-- q: output + +library ieee; +use ieee.std_logic_1164.all; +use ieee.numeric_std.all; + +entity counter is + generic ( + width : positive := 16 + ); + + port ( + clk : in std_logic; + q : out std_logic_vector(width-1 downto 0) + ); +end counter; + +architecture behav of counter is +signal cnt : unsigned(width-1 downto 0) := to_unsigned(0, width); +begin + process + begin + wait until rising_edge(clk); + cnt <= cnt + to_unsigned(1, cnt'length); + end process; + q <= std_logic_vector(cnt); +end behav; + diff --git a/testsuite/gna/bug23165/mwe_failing/mwe.vhd b/testsuite/gna/bug23165/mwe_failing/mwe.vhd new file mode 100644 index 000000000..d3241ac03 --- /dev/null +++ b/testsuite/gna/bug23165/mwe_failing/mwe.vhd @@ -0,0 +1,40 @@ +library ieee; +use ieee.std_logic_1164.all; +use ieee.numeric_std.all; + +entity mwe is +end mwe; + +architecture lulz of mwe is + +constant cnt_len : integer := 2; +constant cnt_stages : integer := 2; + +type ctl_sig is array (natural range <>) of std_logic_vector(cnt_len-1 downto 0); +signal ctl_cnt : ctl_sig(0 to cnt_stages-1); + +signal clk : std_logic := '0'; + +begin + clk <= not clk after 50 ns; + + controller : entity work.counter + generic map( + width => cnt_len + ) + port map( + clk => clk, + q => ctl_cnt(0) + ); + + ctl_cnt_delay : process + begin + wait until rising_edge(clk); + for i in 0 to cnt_stages-2 loop + -- uncomment following line to see that the port map assignment works + -- and that this line just "overwrites" it.. + ctl_cnt(i+1) <= ctl_cnt(i); + end loop; + end process; + +end lulz; diff --git a/testsuite/gna/bug23165/mwe_working/counter.vhd b/testsuite/gna/bug23165/mwe_working/counter.vhd new file mode 100644 index 000000000..9982f1d6c --- /dev/null +++ b/testsuite/gna/bug23165/mwe_working/counter.vhd @@ -0,0 +1,33 @@ +-- counter +-- clk: clock input +-- en: enable input +-- rst: reset input +-- dir: direction pin (1 = up, 0 = down) +-- q: output + +library ieee; +use ieee.std_logic_1164.all; +use ieee.numeric_std.all; + +entity counter is + generic ( + width : positive := 16 + ); + + port ( + clk : in std_logic; + q : out std_logic_vector(width-1 downto 0) + ); +end counter; + +architecture behav of counter is +signal cnt : unsigned(width-1 downto 0) := to_unsigned(0, width); +begin + process + begin + wait until rising_edge(clk); + cnt <= cnt + to_unsigned(1, cnt'length); + end process; + q <= std_logic_vector(cnt); +end behav; + diff --git a/testsuite/gna/bug23165/mwe_working/mwe.vhd b/testsuite/gna/bug23165/mwe_working/mwe.vhd new file mode 100644 index 000000000..8852a8457 --- /dev/null +++ b/testsuite/gna/bug23165/mwe_working/mwe.vhd @@ -0,0 +1,45 @@ +library ieee; +use ieee.std_logic_1164.all; +use ieee.numeric_std.all; + +entity mwe is +end mwe; + +architecture lulz of mwe is + +constant cnt_len : integer := 2; +constant cnt_stages : integer := 2; + +type ctl_sig is array (natural range <>) of std_logic_vector(cnt_len-1 downto 0); +signal ctl_cnt : ctl_sig(0 to cnt_stages-1); +signal ctl_cnt_tmp : ctl_sig(0 to cnt_stages-1); + +signal clk : std_logic := '0'; + +begin + clk <= not clk after 50 ns; + + controller : entity work.counter + generic map( + width => cnt_len + ) + port map( + clk => clk, + q => ctl_cnt(0) + ); + + -- workaround: use concurrent assignment of temporary signal + bla : for k in 1 to cnt_stages-1 generate + ctl_cnt(k) <= ctl_cnt_tmp(k); + end generate bla; + + ctl_cnt_delay : process + begin + wait until rising_edge(clk); + for i in 0 to cnt_stages-2 loop + -- then this works... + ctl_cnt_tmp(i+1) <= ctl_cnt(i); + end loop; + end process; + +end lulz; diff --git a/testsuite/gna/bug23165/testsuite.sh b/testsuite/gna/bug23165/testsuite.sh new file mode 100755 index 000000000..a8251ed8c --- /dev/null +++ b/testsuite/gna/bug23165/testsuite.sh @@ -0,0 +1,15 @@ +#! /bin/sh + +. ../../testenv.sh + +analyze mwe_failing/counter.vhd +analyze mwe_failing/mwe.vhd +elab_simulate mwe --stop-time=100us + +analyze mwe_working/counter.vhd +analyze mwe_working/mwe.vhd +elab_simulate mwe --stop-time=100us --wave=output.ghw + +clean + +echo "Test successful" -- cgit v1.2.3