From fd836e03fbd809d870cee9de6bf58bac297af873 Mon Sep 17 00:00:00 2001 From: Tristan Gingold Date: Wed, 12 Jun 2019 19:49:56 +0200 Subject: Add reproducer for #838 --- testsuite/gna/issue838/testsuite.sh | 11 +++++++ testsuite/gna/issue838/top.vhdl | 58 +++++++++++++++++++++++++++++++++++++ 2 files changed, 69 insertions(+) create mode 100755 testsuite/gna/issue838/testsuite.sh create mode 100644 testsuite/gna/issue838/top.vhdl (limited to 'testsuite/gna') diff --git a/testsuite/gna/issue838/testsuite.sh b/testsuite/gna/issue838/testsuite.sh new file mode 100755 index 000000000..3ac9c0e6b --- /dev/null +++ b/testsuite/gna/issue838/testsuite.sh @@ -0,0 +1,11 @@ +#! /bin/sh + +. ../../testenv.sh + +GHDL_STD_FLAGS=--std=08 +analyze_failure top.vhdl +analyze -frelaxed-rules top.vhdl + +clean + +echo "Test successful" diff --git a/testsuite/gna/issue838/top.vhdl b/testsuite/gna/issue838/top.vhdl new file mode 100644 index 000000000..6ece4b00f --- /dev/null +++ b/testsuite/gna/issue838/top.vhdl @@ -0,0 +1,58 @@ +library ieee; +use ieee.std_logic_1164.all; +use ieee.numeric_std.all; + +entity fpga_avalon_top is + port( + -- Zynq Clock/Reset + pl_fclk :in std_logic; + pl_areset_n :in std_logic; + + -- AVALON S-Port + s_amm_wait :out std_logic; + s_amm_addr :in std_logic_vector(31 downto 0); + s_amm_byte_en :in std_logic_vector(1 downto 0); + s_amm_rd_en :in std_logic; + s_amm_rd_data :out std_logic_vector(31 downto 0); + s_amm_rd_valid :out std_logic; + s_amm_wr_en :in std_logic; + s_amm_wr_data :in std_logic_vector(31 downto 0); + s_amm_wr_resvld :out std_logic; + s_amm_response :out std_logic_vector(1 downto 0); + + -- AVALON M-Port + m_amm_wait :in std_logic; + m_amm_addr :out std_logic_vector(31 downto 0); + m_amm_rd_en :out std_logic; + m_amm_rd_data :in std_logic_vector(31 downto 0); + m_amm_rd_valid :in std_logic; + m_amm_wr_en :out std_logic; + m_amm_wr_data :out std_logic_vector(31 downto 0) +); + +end entity; + +architecture rtl of fpga_avalon_top is + +-- UNCOMMENT WHEN ADDING TO VIVADO, COMMENT-OUT WHEN SIMULATING IN GHDL: +ATTRIBUTE X_INTERFACE_INFO : STRING; +ATTRIBUTE X_INTERFACE_INFO of s_amm_wait :SIGNAL is "xilinx.com:interface:avalon:1.0 s_amm WAITREQUEST"; +ATTRIBUTE X_INTERFACE_INFO of s_amm_addr :SIGNAL is "xilinx.com:interface:avalon:1.0 s_amm ADDRESS"; +ATTRIBUTE X_INTERFACE_INFO of s_amm_byte_en :SIGNAL is "xilinx.com:interface:avalon:1.0 s_amm BYTEENABLE"; +ATTRIBUTE X_INTERFACE_INFO of s_amm_rd_en :SIGNAL is "xilinx.com:interface:avalon:1.0 s_amm READ"; +ATTRIBUTE X_INTERFACE_INFO of s_amm_rd_data :SIGNAL is "xilinx.com:interface:avalon:1.0 s_amm READDATA"; +ATTRIBUTE X_INTERFACE_INFO of s_amm_rd_valid :SIGNAL is "xilinx.com:interface:avalon:1.0 s_amm READDATAVALID"; +ATTRIBUTE X_INTERFACE_INFO of s_amm_wr_en :SIGNAL is "xilinx.com:interface:avalon:1.0 s_amm WRITE"; +ATTRIBUTE X_INTERFACE_INFO of s_amm_wr_data :SIGNAL is "xilinx.com:interface:avalon:1.0 s_amm WRITEDATA"; +ATTRIBUTE X_INTERFACE_INFO of s_amm_wr_resvld :SIGNAL is "xilinx.com:interface:avalon:1.0 s_amm WRITERESPONSEVALID"; +ATTRIBUTE X_INTERFACE_INFO of s_amm_response :SIGNAL is "xilinx.com:interface:avalon:1.0 s_amm RESPONSE"; +ATTRIBUTE X_INTERFACE_INFO of m_amm_wait :SIGNAL is "xilinx.com:interface:avalon:1.0 m_amm WAITREQUEST"; +ATTRIBUTE X_INTERFACE_INFO of m_amm_addr :SIGNAL is "xilinx.com:interface:avalon:1.0 m_amm ADDRESS"; +ATTRIBUTE X_INTERFACE_INFO of m_amm_rd_en :SIGNAL is "xilinx.com:interface:avalon:1.0 m_amm READ"; +ATTRIBUTE X_INTERFACE_INFO of m_amm_rd_data :SIGNAL is "xilinx.com:interface:avalon:1.0 m_amm READDATA"; +ATTRIBUTE X_INTERFACE_INFO of m_amm_rd_valid :SIGNAL is "xilinx.com:interface:avalon:1.0 m_amm READDATAVALID"; +ATTRIBUTE X_INTERFACE_INFO of m_amm_wr_en :SIGNAL is "xilinx.com:interface:avalon:1.0 m_amm WRITE"; +ATTRIBUTE X_INTERFACE_INFO of m_amm_wr_data :SIGNAL is "xilinx.com:interface:avalon:1.0 m_amm WRITEDATA"; +begin + +end architecture; -- cgit v1.2.3