diff options
author | Tristan Gingold <tgingold@free.fr> | 2017-12-16 21:36:44 +0100 |
---|---|---|
committer | Tristan Gingold <tgingold@free.fr> | 2017-12-18 06:06:52 +0100 |
commit | 42b68d5ff95a15e684c16b53a0f1afbde5955f7a (patch) | |
tree | ed295bd24755dc00bc76b3eaded224e0daca8379 /testsuite/gna/bug083/repro3.vhdl | |
parent | 0a8b33fcff3d8c893ec7493ce1e06aeaa00305a0 (diff) | |
download | ghdl-42b68d5ff95a15e684c16b53a0f1afbde5955f7a.tar.gz ghdl-42b68d5ff95a15e684c16b53a0f1afbde5955f7a.tar.bz2 ghdl-42b68d5ff95a15e684c16b53a0f1afbde5955f7a.zip |
Add testcase for previous patch
Diffstat (limited to 'testsuite/gna/bug083/repro3.vhdl')
-rw-r--r-- | testsuite/gna/bug083/repro3.vhdl | 67 |
1 files changed, 67 insertions, 0 deletions
diff --git a/testsuite/gna/bug083/repro3.vhdl b/testsuite/gna/bug083/repro3.vhdl new file mode 100644 index 000000000..455609e5e --- /dev/null +++ b/testsuite/gna/bug083/repro3.vhdl @@ -0,0 +1,67 @@ +library ieee; +use ieee.std_logic_1164.all; + +entity repro3 is +end; + +architecture behav of repro3 is + type t_axilite_write_address_channel is record + --DUT inputs + awaddr : std_logic_vector; + awvalid : std_logic; + end record; + + type t_axilite_write_data_channel is record + --DUT inputs + wdata : std_logic_vector; + wstrb : std_logic_vector; + wvalid : std_logic; + --DUT outputs + wready : std_logic; + end record; + + type t_axilite_read_address_channel is record + --DUT inputs + araddr : std_logic_vector; + arvalid : std_logic; + arprot : std_logic_vector(2 downto 0); + --DUT outputs + arready : std_logic; + end record; + + type t_axilite_read_data_channel is record + --DUT inputs + rready : std_logic; + --DUT outputs + rdata : std_logic_vector; + rresp : std_logic_vector(1 downto 0); + rvalid : std_logic; + end record; + + type t_axilite_if is record + write_address_channel : t_axilite_write_address_channel; + write_data_channel : t_axilite_write_data_channel; + read_address_channel : t_axilite_read_address_channel; + read_data_channel : t_axilite_read_data_channel; + end record; + + function get_w return natural is + begin + return 32; + end get_w; +begin + + process + constant addr_width : natural := get_w; + constant data_width : natural := get_w; + + variable init_if : t_axilite_if + ( write_address_channel( awaddr( addr_width -1 downto 0)), + write_data_channel( wdata( data_width -1 downto 0), + wstrb(( data_width/8) -1 downto 0)), + read_address_channel( araddr( addr_width -1 downto 0)), + read_data_channel( rdata( data_width -1 downto 0))); + begin + wait; + end process; +end behav; |