aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorTristan Gingold <tgingold@free.fr>2019-11-05 04:48:38 +0100
committerTristan Gingold <tgingold@free.fr>2019-11-05 04:48:38 +0100
commite7432e0ba23e9eb78bb7a381ac4d34431d60b3a1 (patch)
treea61427cbf2132bd22e07ce47eea2b20c35a03cd8
parent153a136a1b071e900ab2199fb701d9a1a29599cd (diff)
downloadghdl-yosys-plugin-e7432e0ba23e9eb78bb7a381ac4d34431d60b3a1.tar.gz
ghdl-yosys-plugin-e7432e0ba23e9eb78bb7a381ac4d34431d60b3a1.tar.bz2
ghdl-yosys-plugin-e7432e0ba23e9eb78bb7a381ac4d34431d60b3a1.zip
testsuite: add case for issue 999
-rw-r--r--testsuite/ghdl-issues/issue999/test.vhdl35
-rwxr-xr-xtestsuite/ghdl-issues/issue999/testsuite.sh8
2 files changed, 43 insertions, 0 deletions
diff --git a/testsuite/ghdl-issues/issue999/test.vhdl b/testsuite/ghdl-issues/issue999/test.vhdl
new file mode 100644
index 0000000..71357c3
--- /dev/null
+++ b/testsuite/ghdl-issues/issue999/test.vhdl
@@ -0,0 +1,35 @@
+library ieee;
+use ieee.std_logic_1164.all;
+use ieee.numeric_std.all;
+
+entity test is
+ port(
+ clk : in std_logic;
+
+ read_reg : in std_ulogic_vector(4 downto 0);
+ read_data : out std_ulogic_vector(63 downto 0);
+
+ write_enable : in std_ulogic;
+ write_reg : in std_ulogic_vector(4 downto 0);
+ write_data : in std_ulogic_vector(63 downto 0)
+ );
+end entity test;
+
+architecture behaviour of test is
+ type regfile is array(0 to 31) of std_ulogic_vector(63 downto 0);
+ signal registers : regfile := (others => (others => '0'));
+begin
+ register_write_0: process(clk)
+ begin
+ if rising_edge(clk) then
+ if write_enable = '1' then
+ registers(to_integer(unsigned(write_reg))) <= write_data;
+ end if;
+ end if;
+ end process register_write_0;
+
+ register_read_0: process(all)
+ begin
+ read_data <= registers(to_integer(unsigned(read_reg)));
+ end process register_read_0;
+end architecture behaviour;
diff --git a/testsuite/ghdl-issues/issue999/testsuite.sh b/testsuite/ghdl-issues/issue999/testsuite.sh
new file mode 100755
index 0000000..981976c
--- /dev/null
+++ b/testsuite/ghdl-issues/issue999/testsuite.sh
@@ -0,0 +1,8 @@
+#!/bin/sh
+
+topdir=../..
+. $topdir/testenv.sh
+
+synth_import --std=08 test.vhdl -e
+
+clean