news 2026/4/16 10:58:06

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

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
慢时钟域到快时钟域问题(打拍法)(自用)

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

  1. 亚稳态及其传播

重点! 通过两级寄存器,即使产生亚稳态也在两个寄存器之间,降低传递到后级的概率,从而减轻亚稳态对后级影响。
理论上,亚稳态产生后持续时长是随机的,意味着永远持续下去也是可能的,然而由于实际电路中存在的噪声和能量变化等一定会让亚稳态很快产生不平衡,迅速向0或者1靠拢。举个例子,就像笔尖上放一个圆球,理论上可以找一个位置永远平衡,然而实际上由于一点点的震动都会导致圆球迅速掉下去。在时钟发射沿到来后,亚稳态产生后持续时间为Tmet,在捕获沿到来时,dout的亚稳态已经消除,这样亚稳态就不会往后级传播,也就是说亚稳态在一个时钟周期内稳定就可以防止往下一级传播。实际中亚稳态的稳定都很快。而同步器打2拍就是为了在时钟频率很高的时候,捕获沿采到亚稳态向下一级传播的时候,还有一级寄存器隔离,然亚稳态在一个时钟周期内稳定下来。
假设,亚稳态在一个时钟周期内稳定不下来的概率为P,0<P<1,那么经过一级打拍稳定下来概率为1-P,经过两级打拍稳定下来的概率为1-P^2,以此类推。所以打拍越多越容易稳定下来,防止亚稳态传播。

50M快时钟与异步25M慢时钟时钟域问题,通过打拍解决并且实现上升沿检测
modelsim仿真与分析一致
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
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/13 9:46:52

OpenCore-Configurator 终极指南:轻松配置黑苹果引导系统

OpenCore-Configurator 终极指南&#xff1a;轻松配置黑苹果引导系统 【免费下载链接】OpenCore-Configurator A configurator for the OpenCore Bootloader 项目地址: https://gitcode.com/gh_mirrors/op/OpenCore-Configurator OpenCore-Configurator&#xff08;简称…

作者头像 李华
网站建设 2026/4/5 20:24:25

EldenRingSaveCopier终极指南:如何安全迁移艾尔登法环存档

EldenRingSaveCopier终极指南&#xff1a;如何安全迁移艾尔登法环存档 【免费下载链接】EldenRingSaveCopier 项目地址: https://gitcode.com/gh_mirrors/el/EldenRingSaveCopier 你是否曾因更换电脑或游戏版本更新而担心丢失数百小时的游戏进度&#xff1f;EldenRingS…

作者头像 李华
网站建设 2026/4/16 10:42:54

PyQt6快速上手:GUI开发从入门到实战完整教程

PyQt6快速上手&#xff1a;GUI开发从入门到实战完整教程 【免费下载链接】PyQt-Chinese-tutorial PyQt6中文教程 项目地址: https://gitcode.com/gh_mirrors/py/PyQt-Chinese-tutorial PyQt6中文教程项目是专为零基础开发者设计的GUI编程学习资源&#xff0c;通过系统化…

作者头像 李华
网站建设 2026/4/15 12:04:06

TikTok评论采集工具完整使用指南:从零开始掌握数据抓取

TikTok评论采集工具完整使用指南&#xff1a;从零开始掌握数据抓取 【免费下载链接】TikTokCommentScraper 项目地址: https://gitcode.com/gh_mirrors/ti/TikTokCommentScraper TikTokCommentScraper是一款专业的社交媒体数据采集工具&#xff0c;能够帮助用户快速提取…

作者头像 李华
网站建设 2026/4/15 3:43:40

Windows Defender完全卸载指南:三步骤彻底移除系统防护

还在为Windows Defender频繁的资源占用而困扰吗&#xff1f;手动禁用总是被系统自动恢复&#xff1f;本文将为你详细介绍如何使用windows-defender-remover项目&#xff0c;通过三种不同的操作模式&#xff0c;彻底解决Windows Defender带来的各种问题。 【免费下载链接】windo…

作者头像 李华