diff options
author | Tristan Gingold <tgingold@free.fr> | 2019-11-05 04:27:29 +0100 |
---|---|---|
committer | Tristan Gingold <tgingold@free.fr> | 2019-11-05 04:27:29 +0100 |
commit | 43e40cf55988f11df0fd81d39d917f96bf1579de (patch) | |
tree | dbe0415a04e6142a4354e765464c6b8b4a48fc95 | |
parent | 11b7d45a180145d943f2c3c2460aa89e91e146d7 (diff) | |
download | ghdl-yosys-plugin-43e40cf55988f11df0fd81d39d917f96bf1579de.tar.gz ghdl-yosys-plugin-43e40cf55988f11df0fd81d39d917f96bf1579de.tar.bz2 ghdl-yosys-plugin-43e40cf55988f11df0fd81d39d917f96bf1579de.zip |
testsuite: add issue1000
-rw-r--r-- | testsuite/ghdl-issues/issue1000/test.vhdl | 43 | ||||
-rwxr-xr-x | testsuite/ghdl-issues/issue1000/testsuite.sh | 8 |
2 files changed, 51 insertions, 0 deletions
diff --git a/testsuite/ghdl-issues/issue1000/test.vhdl b/testsuite/ghdl-issues/issue1000/test.vhdl new file mode 100644 index 0000000..a6ef1e3 --- /dev/null +++ b/testsuite/ghdl-issues/issue1000/test.vhdl @@ -0,0 +1,43 @@ +library ieee; +use ieee.std_logic_1164.all; +use ieee.numeric_std.all; + +entity test is + port( + clk : in std_logic; + + read1_reg : in std_ulogic_vector(4 downto 0); + read1_data : out std_ulogic_vector(63 downto 0); + + read2_reg : in std_ulogic_vector(4 downto 0); + read2_data : out std_ulogic_vector(63 downto 0); + + read3_reg : in std_ulogic_vector(4 downto 0); + read3_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; +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 + read1_data <= registers(to_integer(unsigned(read1_reg))); + read2_data <= registers(to_integer(unsigned(read2_reg))); + read3_data <= registers(to_integer(unsigned(read3_reg))); + end process register_read_0; +end architecture behaviour; diff --git a/testsuite/ghdl-issues/issue1000/testsuite.sh b/testsuite/ghdl-issues/issue1000/testsuite.sh new file mode 100755 index 0000000..981976c --- /dev/null +++ b/testsuite/ghdl-issues/issue1000/testsuite.sh @@ -0,0 +1,8 @@ +#!/bin/sh + +topdir=../.. +. $topdir/testenv.sh + +synth_import --std=08 test.vhdl -e + +clean |