diff options
author | Tristan Gingold <tgingold@free.fr> | 2017-11-01 06:24:38 +0100 |
---|---|---|
committer | Tristan Gingold <tgingold@free.fr> | 2017-11-01 06:24:38 +0100 |
commit | 96f5e9b58e5c96ee1a9540c49bb573cccadee67d (patch) | |
tree | 952b71f49c8ed8156dddfd713923a7026182cfdb /testsuite/gna/issue418/repro.vhdl | |
parent | bf78529db49856d6af45d95b39c4f67ec3366407 (diff) | |
download | ghdl-96f5e9b58e5c96ee1a9540c49bb573cccadee67d.tar.gz ghdl-96f5e9b58e5c96ee1a9540c49bb573cccadee67d.tar.bz2 ghdl-96f5e9b58e5c96ee1a9540c49bb573cccadee67d.zip |
Add reproducer for #418
Diffstat (limited to 'testsuite/gna/issue418/repro.vhdl')
-rw-r--r-- | testsuite/gna/issue418/repro.vhdl | 76 |
1 files changed, 76 insertions, 0 deletions
diff --git a/testsuite/gna/issue418/repro.vhdl b/testsuite/gna/issue418/repro.vhdl new file mode 100644 index 000000000..1d0c625bd --- /dev/null +++ b/testsuite/gna/issue418/repro.vhdl @@ -0,0 +1,76 @@ +entity repro is +end; + +library ieee; +use ieee.std_logic_1164.all; + +architecture behav of repro is + -- AXI-Lite Interface signals + type t_axilite_write_address_channel is record + --DUT inputs + awaddr : std_logic_vector; + awvalid : std_logic; + awprot : std_logic_vector(2 downto 0); -- [0: '0' - unpriviliged access, '1' - priviliged access; 1: '0' - secure access, '1' - non-secure access, 2: '0' - Data access, '1' - Instruction accesss] + --DUT outputs + awready : 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_write_response_channel is record + --DUT inputs + bready : std_logic; + --DUT outputs + bresp : std_logic_vector(1 downto 0); + bvalid : 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); -- [0: '0' - unpriviliged access, '1' - priviliged access; 1: '0' - secure access, '1' - non-secure access, 2: '0' - Data access, '1' - Instruction accesss] + --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; + write_response_channel : t_axilite_write_response_channel; + read_address_channel : t_axilite_read_address_channel; + read_data_channel : t_axilite_read_data_channel; + end record; + + subtype ST_AXILite_32 is t_axilite_if ( + write_address_channel ( + awaddr(31 downto 0) ), + write_data_channel ( + wdata(31 downto 0), + wstrb(3 downto 0) ), + read_address_channel ( + araddr(31 downto 0) ), + read_data_channel ( + rdata(31 downto 0) ) + ); + + signal s : st_axilite_32; +begin + s.write_address_channel.awaddr <= x"0000_1000", x"1000_ffff" after 2 ns; +end; |