如何在vhdl中使用可变大小的端口实例化多个组件?

时间:2018-06-26 20:59:36

标签: vhdl quartus

我想重复地详细说明几个用于generate语句的组件,这些组件具有可变大小的端口,我不知道如何将这些可变大小的端口分配给信号。

我正在使用带有以下声明的软件包:

library ieee;
use ieee.std_logic_1164.all;

PACKAGE Arrays_package IS
    type Generic_ARRAY_type is array (integer range <>) of std_logic_vector;
END Arrays_package;

以下代码中的组件为Pre_pre_buffer_convPre_buffer_conv

如何声明信号xdataout_preprebuffer

library ieee;
use ieee.std_logic_1164.all;
use work.Arrays_package.all;

entity Naive_RNC_problem is

    generic(
                no_col_imag     : integer := 28;
                no_bits         : integer := 9; 
                no_bits_fraction : natural := 8;
                no_col_filt     : integer := 3 
    );  

    port 
    (
    CLOCK_50   : in std_logic;
    KEY        : in std_logic_vector(3 downto 0);
    SW         : in std_logic_vector(17 downto 0);

    xdataout_pre_buffer_conv : out Generic_ARRAY_type(no_col_filt*no_col_filt-1 downto 0)((no_bits-1) downto 0)

    );

end entity;

architecture rtl of Naive_RNC_problem is

component Image_ROM IS
    PORT
    (
        address     : IN STD_LOGIC_VECTOR (9 DOWNTO 0);
        clock       : IN STD_LOGIC  := '1';
        q       : OUT STD_LOGIC_VECTOR (8 DOWNTO 0)
    );
END component;

component generic_mask_nxn_v2 is
    generic(
                no_col_imag     : integer := 28;
                no_col_filt     : integer := 3;
                stride          : integer := 1;
                no_bits         : integer := 10 
    );  

    Port (
            -- ENTRADAS ------------------------
                iclk, irst    : in std_logic;
                ien               : in std_logic;
                idatain           : in std_logic_vector (no_bits-1 downto 0);
                index         : in integer;
                iindex_ctrl   : in std_logic_vector(7 downto 0);
            -- SALIDAS -------------------------
               odataout   : out Generic_ARRAY_type(no_col_filt-1 downto 0)((no_col_filt*no_bits-1) downto 0) ;
                omasken     : out std_logic

          );
end component;

component Pre_pre_buffer_conv is
    generic 
    (
        no_col_filt     : integer := 3;
        no_bits         : integer := 10 
    );

    port 
    (           
    -- ENTRADAS ------------------------
        iclk, irst    : in std_logic;
        ien               : in std_logic;
        index         : in integer;
        iindex_ctrl   : in std_logic_vector(7 downto 0);
        idatain           : in  Generic_ARRAY_type(no_col_filt-1 downto 0)(no_col_filt*no_bits-1 downto 0);
    -- SALIDAS -------------------------
        odataout          : out Generic_ARRAY_type(no_col_filt-1 downto 0)(no_col_filt*no_bits-1 downto 0)  
    );
end component;

component Pre_buffer_conv is
    generic 
    (
        no_col_filt     : integer := 3;
        no_bits         : integer := 9 
    );

    port 
    (           
    -- ENTRADAS ------------------------
        iclk, irst    : in std_logic;
        ien               : in std_logic;
        idatain           : in Generic_ARRAY_type(no_col_filt-1 downto 0)(no_col_filt*no_bits-1 downto 0);
        isel_row         : in std_logic_vector(3 downto 0);
        isel_col         : in std_logic_vector(3 downto 0);
    -- SALIDAS -------------------------
        odataout          : out std_logic_vector (no_bits-1 downto 0)
    );
end component;

component Top_Control_prepre_buffer is
    port (-- ENTRADAS -----------
            iclk, ireset     : in std_logic;

            iStart          : in std_logic;
            imasken_conv    : in std_logic;
            ifin_convolvers   : in std_logic;
            ifin_interfaz_Conv_pool : in std_logic;

            -- SALIDAS -----------------------
            oidle           : out std_logic;
            orst            : out std_logic;
            oen_line_buffer_conv : out std_logic;
            odir_imagen     : out std_logic_Vector(15 downto 0);
            ocarga_prepre_buffer     : out std_logic;
            ocarga_pre_buffer_conv   : out std_logic;
            oind_pre_buffers_conv : out std_logic_Vector(15 downto 0);
            oStart_convolver         : out std_logic;
            oinicia_interfaz_Conv_pool : out std_logic
    );      
end component;

--=======================================================
--  Signal  declarations
--=======================================================

signal xRST            : std_logic;
signal xrst_ctrl       : std_logic;
signal xStart          : std_logic;
signal xclk_50 : std_logic;
signal xaddress_memoria_MNIST_ROM, xaddress_MNIST_PORTA: STD_LOGIC_VECTOR (9 DOWNTO 0);
signal xdataout_MNIST_ROM    : STD_LOGIC_VECTOR (8 DOWNTO 0);
signal xaddress_memoria_MNIST_ctrl : STD_LOGIC_VECTOR (15 DOWNTO 0);
signal  xrst_buffer_conv      :  std_logic;
signal  xdatain_buffer  :  std_logic_vector (no_bits-1 downto 0);
signal   xdataout_buffer  : Generic_ARRAY_type(no_col_filt-1 downto 0)((no_col_filt*no_bits-1) downto 0) ;      
signal  xmasken_buffer    :  std_logic;
signal   xen_line_buffer_conv   : std_logic;        
signal xcarga_prepre_buffer : std_logic;
signal xsel_row_pre_buffer : std_logic_vector(3 downto 0);
signal xsel_col_pre_buffer : std_logic_vector(3 downto 0); 
signal xstart_fill_buffers_conv : std_logic;
signal xcarga_pre_buffer_conv : std_logic;
signal xind_pre_buffers_conv_ctrl : std_logic_vector(15 downto 0);
signal xind_pre_buffers_conv : std_logic_vector(7 downto 0);
signal xrst_contol_prepre_buffer : std_logic;
signal xfin_convolver, xfin_Interfaz_conv_pool : std_logic;

    --  how to declare this signal? ---------------------------
type my_type1 is array (no_col_filt-1 downto 0) of std_logic_vector((no_col_filt*no_bits-1) downto 0);
type my_type2 is array(no_col_filt*no_col_filt-1 downto 0) of my_type1;
signal xdataout_preprebuffer : my_type2;
    ----
--=======================================================
--  Structural coding
--=======================================================


begin

xRST <= not KEY(0);
xStart <= not KEY(1);

-- RELOJES ===============================================

    xclk_50 <= CLOCK_50;

-- MEMORIA IMAGEN MNIST ===============================================

    MemoriaROM_MNIST : Image_ROM port map (xaddress_memoria_MNIST_ROM, xclk_50, xdataout_MNIST_ROM);

    xaddress_memoria_MNIST_ROM <= xaddress_memoria_MNIST_Ctrl(9 downto 0); 


-- Line Buffer convolucion ==============================================

    Buffer_mask : generic_mask_nxn_v2 generic map ( no_col_imag => no_col_imag,
                                                              no_col_filt => no_col_filt,
                                                              stride      => 1,
                                                              no_bits     => no_bits
                                                                )

                                            port map (-- ENTRADAS ------------------------
                                                         xclk_50, xrst_buffer_conv,
                                                         xen_line_buffer_conv, xdatain_buffer,  
                                                         0,
                                                         (others => '0'), 
                                                        -- SALIDAS -------------------------
                                                         xdataout_buffer, -- this is a variable size port (no problem here)
                                                         xmasken_buffer 
                                                            );

    xrst_buffer_conv <=  xRST or xrst_ctrl ;--(not xRST) or
    xdatain_buffer <= xdataout_MNIST_ROM;

    -- Control Prepre Buffer convolucion ==============================================

    Prepre_buffer_ctrl : Top_Control_prepre_buffer port map (-- ENTRADAS -----------------------
                                                                xclk_50, xrst_contol_prepre_buffer, 
                                                                xStart,
                                                                xmasken_buffer,
                                                                xfin_convolver,
                                                                xfin_Interfaz_conv_pool, 
                                                              -- SALIDAS -----------------------
                                                              open, xrst_ctrl, 
                                                              xen_line_buffer_conv, 
                                                              xaddress_memoria_MNIST_ctrl,                                                        
                                                              xcarga_prepre_buffer, xcarga_pre_buffer_conv, xind_pre_buffers_conv_ctrl,
                                                              open,
                                                              open

                                                                );
    xrst_contol_prepre_buffer <= xRST;
    xfin_convolver <= '1';  
    xfin_Interfaz_conv_pool <= '1';

-- Pre pre Buffer convolucion ===========================================

    pre_pre_buffers_conV : for i in 0 to (no_col_filt*no_col_filt-1) generate
        pre_pre_buffer_conV_cmp : Pre_pre_buffer_conv generic map (no_col_filt => no_col_filt,
                                                                            no_bits     => no_bits 
                                                                            )
                                                                     port map (-- ENTRADAS -----------------------
                                                                        xclk_50, xrst_buffer_conv,
                                                                        xcarga_prepre_buffer,
                                                                        i,
                                                                        xind_pre_buffers_conv,
                                                                        xdataout_buffer, -- this is a variable size port (no problem here)
                                                                        -- SALIDAS -----------------------
                                                                        xdataout_preprebuffer(i) -- this is a variable size port (ERROR HERE)
                                                                  );            

    end generate;


-- Pre Buffer convolucion ==============================================

    pre_buffers_conV : for i in 0 to (no_col_filt*no_col_filt-1) generate
        pre_buffer_conV_cmp : Pre_buffer_conv generic map (no_col_filt => no_col_filt,
                                                                            no_bits     => no_bits 
                                                                            )
                                                          port map (-- ENTRADAS -----------------------
                                                                        xclk_50, xrst_buffer_conv,
                                                                        xcarga_pre_buffer_conv,
                                                                        xdataout_preprebuffer(i),  -- this is a variable size port (ERROR HERE)
                                                                        xsel_row_pre_buffer,
                                                                        xsel_col_pre_buffer,
                                                                        -- SALIDAS -----------------------
                                                                        xdataout_pre_buffer_conv(i)  
                                                                  );    
    end generate;   

   xind_pre_buffers_conv <= xind_pre_buffers_conv_ctrl(7 downto 0); 
    xsel_row_pre_buffer <= (others => '0');
    xsel_col_pre_buffer <= (others => '0');     


end rtl;

分析和阐述阶段抛出的错误是:

  

错误(10381):Naive_RNC_problem.vhd(228)处的VHDL类型不匹配错误:   索引名称返回一个类型不匹配的值   “ Generic_ARRAY_type”,目标表达式的类型

     

错误:Quartus Prime分析和精加工不成功。 1个错误,   0条警告

我认为信号xdataout_preprebuffer必须声明为2d阵列信号,但是我不知道该怎么做。

1 个答案:

答案 0 :(得分:1)

两个变化。

包装中添加的类型:

library ieee;
use ieee.std_logic_1164.all;

package arrays_package is
    type generic_array_type is array (integer range <>) of std_logic_vector;
    type generic_array_of_generic_type is   -- ADDED type
                            array (integer range <>) of generic_array_type;
end package arrays_package;

和信号声明:

signal xdataout_preprebuffer:   generic_array_of_generic_type  -- type mark
                            -- index subtype:
                                    (no_col_filt * no_bits - 1 downto 0) 
                            -- element constraint (generic_array_type):
                                -- index subtype:
                                    (no_col_filt - 1 downto 0)
                                --  element index constraint (std_logic_vector):
                                    (no_col_filt * no_bits - 1 downto 0);

之后,您的代码将进行分析(详细说明和仿真需要在详细说明过程中将所有这些组件绑定到的实体。对于组件的实体声明和虚拟体系结构主体,您的代码将进行详细说明和仿真(显示关联和分配没有边界错误)。

添加的类型与原始类型一样使用-2008无界数组定义(请参阅IEEE Std 1076-2008 5.3.2数组类型,5.3.2.1常规, 5.3.2.2索引约束和离散范围,6.3子类型声明)。

我们拥有的是一个无界的一维数组类型(generic_array_of_generic_type),其元素类型(无界的一维类型generic_array_type)具有自己的元素无界的一维数组类型(std_logic_vector)。在对象声明期间提供了无边界数组类型的索引约束。