VHDL-带反馈的相位累加器

时间:2019-02-05 19:05:04

标签: vhdl feedback accumulator phase

我正在尝试使用具有以下特征的VHDL创建一个相位累加器。

输入:

  • D(输入信号)
  • 重置
  • CE
  • CLK

输出:

  • Q(输出信号-反馈)

源代码:

library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
use IEEE.STD_LOGIC_ARITH.ALL;
use IEEE.STD_LOGIC_UNSIGNED.ALL;
entity Phase_accu is
port (
    D       : in std_logic_vector(3 downto 0);
    CE      : in std_logic;
    CLK     : in std_logic;
    RESET   : in std_logic;
    Q       : out std_logic_vector(15 downto 0)
);
end Phase_accu;

architecture Behavioral of Phase_accu is
begin

process(D, CE, CLK, RESET)
    begin
        if RESET = '1' then
            Q <= "0000000000000000";
        elsif rising_edge(CLK) then
            if CE = '1' then
                Q <= ("000000000000" & D) + Q;
            end if;
        end if;
end process;

end Behavioral;

我在尝试将2个信号合并以进行反馈的那条线上出现错误...

Q <= ("000000000000" & D) + Q;

无法读取输出“ Q”。

2 个答案:

答案 0 :(得分:6)

在VHDL-2008之前的VHDL版本中,您无法读取debugger;的值。解决此问题的通常方法是拥有输出的内部副本,并在需要获取其值时使用该内部副本:

out

答案 1 :(得分:1)

我建议使用numeric_std库而不是STD_LOGIC_ARITH和STD_LOGIC_UNSIGNED。我还建议对向量大小规范进行一些小的优化。

灵敏度列表也有两个条目。您必须删除D和CE以描述具有异步复位的有效时钟处理过程。有关详细信息,请参见您的综合工具手册。

这使上面的代码成为

library ieee;
use ieee.std_logic_1164.all;
use ieee.numeric_std.all;

entity Phase_accu is
port (
    D       : in std_logic_vector(3 downto 0);
    CE      : in std_logic;
    CLK     : in std_logic;
    RESET   : in std_logic;
    Q       : out std_logic_vector(15 downto 0)
);
end Phase_accu;

architecture Behavioral of Phase_accu is
    signal Q_reg : unsigned(Q'range);
begin

process(CLK, RES)
begin

        if RES = '1' then
            Q_reg <= (others => '0');
        elsif rising_edge(CLK) then
            if CE = '1' then
                Q_reg <= resize(unsigned(D), Q_reg'length) + Q_reg;
            end if;
        end if;

end process;

Q <= std_logic_vector(Q_reg);

end Behavioral;