fpga中异步复位,同步释放

复位可以在任何时候发生,表面上看跟时钟没有关系,但真实情况是异步复位也需考虑时钟跳变沿,因为时钟沿变化和异步复位都可以引起Q端数据变化。同步复位虽然解决了当时钟的有效沿来临的时候rst的边沿也正好来临所出现的冒险与竞争。但是从综合的电路上可以看出,多了一个组合逻辑MUX。如果设计中所有的复位都是这样的,那会增加很多的资源,导致芯片面积很大,而异步复位同步释放机制可以解决这一问题。

异步复位同步释放的主要目的就是在减少资源损耗的同时避免毛刺的出现。其机制如下:

异步复位会出现亚稳态是因为无法保证clk的上升沿时,rst释放信号能够满足其建立保持时间,触发器无法判断rst有效还是无效,因而出现亚稳态;而同步释放的处理机制可以保证rst释放信号的建立时间点与clk的posedge同步,在当前clk的posedge检测到rst稳定的低电平,在下一个clk的posedge可以检测到已经稳定的rst高电平,满足了rst的建立保持时间要求,从而不会出现亚稳态。

fpga中异步复位,同步释放_第1张图片

简单理解: 所谓“异步复位”是针对D触发器的复位端口,它是异步的,所谓“同步释放”,实际上是由于设计了同步逻辑电路,外部复位信号不会在出现释放时与clk信号竞争,整个系统将与全局时钟clk信号同步。

例题:请使用异步复位同步释放来将输入数据a存储到寄存器中,并画图说明异步复位同步释放的机制原理。

fpga中异步复位,同步释放_第2张图片

 

`timescale 1ns/1ns
module ali16(
input clk,
input rst_n,
input d,
output reg dout
 );
//*************code***********//
    reg    syc_rst_n1;
    reg    syc_rst_n2;
    wire    syc_rst_n;
    always@(posedge clk or negedge rst_n)
        if(~rst_n)
            begin
                syc_rst_n1 <= 1'b0;
                syc_rst_n2 <= 1'b0;
            end
    else begin
        syc_rst_n1 <= 1'b1;
        syc_rst_n2 <= syc_rst_n1;
    end
    assign syc_rst_n = syc_rst_n2;
    
    always@(posedge clk or negedge syc_rst_n)
        if(~syc_rst_n)
            dout <= 1'b0;
    else 
        dout <= d;
//*************code***********//
endmodule

你可能感兴趣的:(fpga基础学习,fpga开发)