tanzh106 发表于 2011-3-29 09:40:04

新手求助一个关于计数器产生毛刺的问题

本帖最后由 tanzh106 于 2011-3-29 09:41 编辑

很简单的一个记数模块,实现从0到依次加1到255,然后再回到0的计数输出
代码如下
library ieee;
use ieee.std_logic_1164.all;
entity addr is
        port ( clock : in std_logic;
                   addr : buffer integer range 0 to 255);
end addr;
architecture behav of addr is
begin
        process (clock)
          begin
                if (clock'event and clock='1') then addr<=addr+1;
                  if addr=255 then addr<=0;
              end if;
          end if;
end process;
end behav;

可是为什么仿真波形会有毛刺,请看附件图片
计数值每增加2,就会产生毛刺,如图中的245、246中间247、248之间
求前辈们指点小弟,如何消除
小弟在这里拜谢了

至芯汪老师 发表于 2011-3-29 13:45:45

这个,你用的时序仿真,应该是时钟频率较高导致的,把时钟周期调大一般就没了。

另外 integer的数据类型不好,从开始就养成好习惯,定义成 7 downto 0

roger7313 发表于 2011-3-29 15:17:49

基本上產生glitch算是正常現象
除非你對此要求甚高
可以提供你幾個方向思考
1. 考慮setup time
2. clock調慢
3. 加入constrain

zzzdaizi 发表于 2011-3-29 20:56:09

d触发器好像可以消除毛刺

tanzh106 发表于 2011-3-29 21:40:58

回复 3# roger7313


    您好,想请问一下,如何加入constrain
页: [1]
查看完整版本: 新手求助一个关于计数器产生毛刺的问题