首页 > 其他 > 详细

异步复位 同步释放

时间:2014-07-11 10:21:52      阅读:649      评论:0      收藏:0      [点我收藏+]

  在FPGA设计中常遇到复位的设计,一般情况下,复位分为同步复位和异步复位。

  异步复位与同步复位相比,其利用到了D触发器的CLR端,消耗硬件资源小,所以在很多情况下各个模块的复位方式选取为异步复位。但是异步信号容易产生潜在的危险:当异步复位信号在时钟上升沿附近取消复位状态时,时序电路很可能在此出现问题。

  解决这个问题的一个方法为,对异步复位信号进行预处理,使其成为异步复位、同步释放的形式。

  我设计的电路如下:

library ieee;
use ieee.std_logic_1164.all;
use ieee.std_logic_unsigned.all;

entity Reset is
port(
    CLK:            in        std_logic;
    RST_n_in:        in        std_logic;
    RST_n_out:        buffer     std_logic
);
end Reset;


architecture ex of Reset is
    signal rst_clk_syn:        std_logic;
begin
    RST_n_out <= rst_clk_syn and RST_n_in;
    process(CLK, RST_n_in)
    begin
        if(CLKevent and CLK = 1) then
            rst_clk_syn <= RST_n_in;
        end if;
    end process;
end ex;

  其RTL级综合结果如下:

bubuko.com,布布扣

  其功能仿真结果如下:

bubuko.com,布布扣

  异步复位信号经过这个结构后,再传到其他异步复位模块,便可以减少异步信号造成的不稳定现象。

异步复位 同步释放,布布扣,bubuko.com

异步复位 同步释放

原文:http://www.cnblogs.com/Si-Mao/p/3834430.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!