aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--testsuite/issues/issue36/bram.vhdl33
-rwxr-xr-xtestsuite/issues/issue36/testsuite.sh9
2 files changed, 42 insertions, 0 deletions
diff --git a/testsuite/issues/issue36/bram.vhdl b/testsuite/issues/issue36/bram.vhdl
new file mode 100644
index 0000000..fcfb98b
--- /dev/null
+++ b/testsuite/issues/issue36/bram.vhdl
@@ -0,0 +1,33 @@
+library ieee;
+ use ieee.std_logic_1164.all;
+ use ieee.numeric_std.all;
+
+entity bram is
+ generic (
+ addr_width : integer := 9;
+ data_width : integer := 8
+ );
+ port (
+ clk : in std_logic;
+ we : in std_logic;
+ addr : in std_logic_vector(addr_width-1 downto 0);
+ data_in : in std_logic_vector(data_width-1 downto 0);
+ data_out : out std_logic_vector(data_width-1 downto 0)
+ );
+end bram;
+
+architecture rtl of bram is
+ type mem_type is array (0 to (2**addr_width)-1) of std_logic_vector(data_width-1 downto 0);
+ signal mem : mem_type;
+
+begin
+ process(clk)
+ begin
+ if rising_edge(clk) then
+ if we = '1' then
+ mem(to_integer(unsigned(addr))) <= data_in;
+ end if;
+ end if;
+ end process;
+ data_out <= mem(to_integer(unsigned(addr)));
+end rtl;
diff --git a/testsuite/issues/issue36/testsuite.sh b/testsuite/issues/issue36/testsuite.sh
new file mode 100755
index 0000000..4377ed3
--- /dev/null
+++ b/testsuite/issues/issue36/testsuite.sh
@@ -0,0 +1,9 @@
+#!/bin/sh
+
+topdir=../..
+. $topdir/testenv.sh
+
+synth_import bram.vhdl -e
+
+clean
+echo OK