【发布时间】:2016-11-06 13:35:47
【问题描述】:
我有这个简单的 VHDL 代码aufg4.vhd:
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
entity aufg4 is
Port (
clock : in std_logic
);
end aufg4;
architecture Behavioral of aufg4 is
signal tut_counter : integer range 0 to 90 := 0; -- counts tutorial time
begin
do_process :process(clock)
begin
if(rising_edge(clock)) then
report "tut_counter " & integer'image(tut_counter);
if(tut_counter >= 90) then
tut_counter <= 0;
report "tut_counter reset";
end if;
tut_counter <= tut_counter + 1;
end if;
end process;
end Behavioral;
还有测试平台aufg4_tb.vhd:
LIBRARY ieee;
USE ieee.std_logic_1164.ALL;
ENTITY aufg4_tb IS
END aufg4_tb;
ARCHITECTURE behavior OF aufg4_tb IS
COMPONENT aufg4
PORT(
clock : IN std_logic
);
END COMPONENT;
--Inputs
signal clock : std_logic := '0';
-- Clock period definitions
constant clock_period : time := 10 ns;
BEGIN
-- Instantiate the Unit Under Test (UUT)
uut: aufg4 PORT MAP (
clock => clock
);
-- Clock process definitions
clock_process :process
begin
clock <= '0';
wait for clock_period/2;
clock <= '1';
wait for clock_period/2;
end process;
END;
当我模拟行为模型report 输出时:
...
at 885 ns(1): Note: tut_counter 88 (/aufg4_tb/uut/).
at 895 ns(1): Note: tut_counter 89 (/aufg4_tb/uut/).
at 905 ns(1): Note: tut_counter 90 (/aufg4_tb/uut/).
at 905 ns(1): Note: tut_counter reset (/aufg4_tb/uut/).
at 915 ns(1): Note: tut_counter 91 (/aufg4_tb/uut/).
at 915 ns(1): Note: tut_counter reset (/aufg4_tb/uut/).
at 925 ns(1): Note: tut_counter 92 (/aufg4_tb/uut/).
at 925 ns(1): Note: tut_counter reset (/aufg4_tb/uut/).
at 935 ns(1): Note: tut_counter 93 (/aufg4_tb/uut/).
...
所以if-statement 可以正常工作,但是信号tut_counter 的重新分配不起作用。
那是为什么呢?
为什么模拟没有通过错误,因为tut_counter 的范围只是0 to 90?
【问题讨论】:
-
+1 顺便问了一个很好的问题。至于为什么它不报告错误 - 大胆猜测,您使用的是 Xilinx ISIM。默认情况下它已损坏,并且多年来一直如此,但是有一个“属性”选项(我认为在“高级”选项卡下)可以打开范围检查并修复它..
-
@BrianDrummond 我怎样才能让这种重新分配
event正常工作? -
记住“最后一个任务获胜”,还有一个
else关键字。 -
只是为了澄清布赖恩关于“最后一个任务获胜”的回答。 顺序进程就是这种情况。并发分配发生在“同一时间”(粗略地说,每个都发生在不同的增量周期 - 但相同的时间值(ps、ns等)。
标签: vhdl xilinx-ise