慢时钟域到快时钟域问题(打拍法)(自用)

通过在快时钟域打拍两次实现转换,实验表明3级触发器可以避免99%的时序违例。解决FPGA不同时钟数据同步的亚稳态问题。

  1. 亚稳态及其传播

重点! 通过两级寄存器,即使产生亚稳态也在两个寄存器之间,降低传递到后级的概率,从而减轻亚稳态对后级影响。

理论上,亚稳态产生后持续时长是随机的,意味着永远持续下去也是可能的,然而由于实际电路中存在的噪声和能量变化等一定会让亚稳态很快产生不平衡,迅速向0或者1靠拢。举个例子,就像笔尖上放一个圆球,理论上可以找一个位置永远平衡,然而实际上由于一点点的震动都会导致圆球迅速掉下去。在时钟发射沿到来后,亚稳态产生后持续时间为Tmet,在捕获沿到来时,dout的亚稳态已经消除,这样亚稳态就不会往后级传播,也就是说亚稳态在一个时钟周期内稳定就可以防止往下一级传播。实际中亚稳态的稳定都很快。而同步器打2拍就是为了在时钟频率很高的时候,捕获沿采到亚稳态向下一级传播的时候,还有一级寄存器隔离,然亚稳态在一个时钟周期内稳定下来。

假设,亚稳态在一个时钟周期内稳定不下来的概率为P,0<P<1,那么经过一级打拍稳定下来概率为1-P,经过两级打拍稳定下来的概率为1-P^2,以此类推。所以打拍越多越容易稳定下来,防止亚稳态传播。

50M快时钟与异步25M慢时钟时钟域问题,通过打拍解决并且实现上升沿检测

modelsim仿真与分析一致

XML 复制代码
module delay_clap (
    input                               clk1                       ,//slow clk
    input                               clk2                       ,//quick clk
    input                               rst_n                      ,
    input                               sig1                       ,//clk1_input
    output                              sig2                        //edge_sensor
);
reg                    [   2:0]         sig2_r                     ;

    always @(posedge clk2 or negedge rst_n) begin
        if(!rst_n) begin
            sig2_r <= 'b0;
        end
        else begin
            sig2_r <= {sig2_r[1:0],sig1};
        end
    end

    assign sig2 = sig2_r[1] && !sig2_r[2] ;
endmodule
//---------------------------------------------------------------------
module tb;
reg                                     clk1                       ;
reg                                     clk2                       ;
reg                                     rst_n                      ;
reg                                     sig1                       ;
wire                                    sig2                       ;

always begin
    clk1 = 0;
    #30
    clk1 = 1;
    forever #40 begin
        clk1 = ~clk1;
    end
end  

always #20  clk2 = ~clk2;

initial begin
    clk2    = 0 ;
    rst_n   = 0 ;
    sig1    = 0 ;
end

initial begin
    #10;
    rst_n = 1;
    #20
    sig1 = 1;
    #80
    sig1 = 0;
end

    delay_clap u_delay_clap (
    .clk1                              (clk1                      ),
    .clk2                              (clk2                      ),
    .rst_n                             (rst_n                     ),
    .sig1                              (sig1                      ),
    .sig2                              (sig2                      ) 
);
endmodule
相关推荐
松涛和鸣2 小时前
72、IMX6ULL驱动实战:设备树(DTS/DTB)+ GPIO子系统+Platform总线
linux·服务器·arm开发·数据库·单片机
简单中的复杂3 小时前
【避坑指南】RK3576 Linux SDK 编译:解决 Buildroot 卡死在 host-gcc-final 的终极方案
linux·嵌入式硬件
上海合宙LuatOS3 小时前
LuatOS核心库API——【audio 】
java·网络·单片机·嵌入式硬件·物联网·音视频·硬件工程
Hhh __灏3 小时前
stm32的SRAM内存不足如何分析和优化?堆栈空间如何优化?
单片机
LS_learner4 小时前
Snapd和Apt—Linux 上两种完全不同的软件包管理系统
嵌入式硬件
点灯小铭4 小时前
基于51单片机的双档交流电压表设计与实现
单片机·嵌入式硬件·毕业设计·51单片机·课程设计·期末大作业
厦门辰迈智慧科技有限公司4 小时前
全功能数据采集仪mcu主要用途
单片机·嵌入式硬件·水库大坝安全监测·数据采集仪mcu
jl48638215 小时前
变比测试仪显示屏的“标杆“配置!如何兼顾30000小时寿命与六角矢量图精准显示?
人工智能·经验分享·嵌入式硬件·物联网·人机交互
清风6666665 小时前
基于单片机的智能电热水壶设计与温度控制系统
单片机·嵌入式硬件·毕业设计·课程设计·期末大作业