【IC设计】跨时钟异步处理系列——单比特跨时钟

server/2024/10/22 16:47:33/

文章目录

  • 建立时间和保持时间
  • 单比特信号的跨时钟处理
    • 慢时钟域的信号传输到快时钟域
      • 打两拍
    • 快时钟域的信号传输到慢时钟域
      • 方案一 脉冲展宽+同步 (打拍打拍,进行或)
        • 代码
        • 原理图
      • 方案二 脉冲电平检测+双触发器同步+边沿检测
        • 代码
        • 原理图

建立时间和保持时间

  1. 所谓的建立时间或者保持时间都是在描述一种时钟变化的边沿上的数据状态。
  2. 建立时间:在时钟的有效沿(以上升沿为例)到来之前,数据的输入端信号必须保持稳定的最短时间
  3. 保持时间:在时钟的有效沿(以上升沿为例)到来之后,数据的输入端信号必须保持稳定的最短时间

单比特信号的跨时钟处理

慢时钟域的信号传输到快时钟域

打两拍

快时钟域的信号传输到慢时钟域

在这里插入图片描述
如图所示,第一行是脉冲信号,第二行是慢时钟域的时钟。如果从快时钟域要同步一个脉冲信号到慢时钟域,容易出现上升沿没有采样到脉冲信号的情况。

方案一 脉冲展宽+同步 (打拍打拍,进行或)

在这里插入图片描述

代码
module fast2slow_cdc 
(input   i_clk_f     ,input   i_pluse_f   ,input   i_rst_n     ,input   i_clk_s     ,output  o_pluse_s  
);
/*
always @(posedge i_clk_f) beginr_pluse[0] <= i_pluse_f  ;r_pluse[1] <= r_pluse[0] ;r_pluse[2] <= r_pluse[1] ;r_pluse[3] <= r_pluse[2] ;r_pluse[4] <= r_pluse[3] ;
end
*/reg [2:0]    r_pluse    ;
always @(posedge i_clk_f or negedge i_rst_n) beginif(~i_rst_n)    beginr_pluse <=  'b0;endelse beginr_pluse <= {r_pluse[1:0],i_pluse_f};end
endwire   w_pluse ;
assign  w_pluse = |r_pluse ;reg   r_pluse_d0  ;
reg   r_pluse_d1  ;
always @(posedge i_clk_s) beginr_pluse_d0 <= w_pluse    ;r_pluse_d1 <= r_pluse_d0 ;
endassign  o_pluse_s = r_pluse_d1 ;endmodule

存在的问题:采用脉冲展宽+同步,在或时可能产生毛刺

原理图

在这里插入图片描述

方案二 脉冲电平检测+双触发器同步+边沿检测

优点: 对时序比较友好
缺点: 相邻的脉冲太近时,会检测不到
在这里插入图片描述

代码
module fast2slow_cdc2(input	i_clk_f			,input	i_pluse_f		,input	i_clk_s			,output	o_pluse_s
);reg	r_temp	=	0	;always@(posedge i_clk_f)	beginif(i_pluse_f)r_temp	    <=	~r_temp;elser_temp	<=	r_temp;endreg	r_temp_d0;reg	r_temp_d1;reg	r_temp_d2;always@(posedge i_clk_s)	beginr_temp_d0	<=	r_temp		;r_temp_d1	<=	r_temp_d0	;r_temp_d2	<=	r_temp_d1	;endassign o_pluse_s	=	r_temp_d2	^	r_temp_d1	;
endmodule
原理图

在这里插入图片描述


http://www.ppmy.cn/server/107129.html

相关文章

VS2022搭建QT及OpenCV环境

1.背景 由于之前VS2022和QT已经安装好了&#xff0c;所以本次的任务主要是下载OpenCV以及在VS2022上集成QT和OpenCV。关于VS2022和QT的安装大家可以参考别的博客。QT选择的版本是6.2.4&#xff0c;OpenCV版本为3.4.5&#xff0c;Windows版本为Win11。 2.OpenCV下载 OpenCV官…

Spring Web MVC入门

目录 一、建立连接&#xff08;ResquestMapping- 实现URL路由映射&#xff09; 二、发送请求 1、传递单个参数 2、传递多个参数 3、传递对象 4、后端参数重命名&#xff08;后端参数映射&#xff09;&#xff08;RequestParam&#xff09; 5、非必传参数的设置&#xff0…

前端Html5/Css3—div盒子模型

文章目录 第六章 盒子模型6.1 border边框6.2 border-width粗细6.3 border-style边框样式6.4 border简写6.5 margin外边距6.6 padding内边距6.7 盒子模型尺寸6.8 box-sizing6.9 border-radius圆角边框6.9.1 制作圆形6.9.2 半圆6.9.3 四分之一圆 6.10 box-shadow盒子阴影 第六章 …

掀起社交娱乐新浪潮!AI如何应用到短视频APP?

随着人工智能技术的迅速发展和全球社交媒体用户的增长&#xff0c;AI视频生成应用正逐渐成为短视频社交媒体中的关键工具。AI工具不仅可以提高内容的创造效率&#xff0c;还能为用户带来全新的互动体验。 人工智能&#xff08;AI&#xff09;已经成为我们日常生活和工作中不可或…

K8S持久化存储数据volumeMountsvolumes

环境&#xff1a; Ubuntu-1:192.168.114.110作为主 Ubuntu-2:192.168.114.120作为从1&#xff0c;node节点1 Ubuntu-3:192.168.114.130作为从2&#xff0c;node节点2 持久化volumeMounts pod里面&#xff1a;emptyDir和hostPath。存储在node&#xff0c;NFS...&#xff0c;Clo…

力扣经典题目之->相同的树(递归判断两颗二叉树是否相同)

一&#xff1a;题目 二&#xff1a;代码 三&#xff1a;递归展开 第一种模型&#xff1a; 递归展开图&#xff1a; 左&#xff1a; 右&#xff1a; 第二种模型及其递归展开图&#xff1a; 解释&#xff1a; 递归思路即&#xff1a;根相同&#xff0c;左子树相同&#xff0c;…

以太网PHY驱动调试笔记(KSZ8081)

PHY驱动调试笔记 准备知识MAC、RMII、PHY以太网类型100BASE-TX10BASE-5 准备知识 MAC、RMII、PHY 此基本概念可参考一下两篇优秀博文&#xff1a; Ethernet&#xff08;以太网&#xff09;之一 详解 MAC、MII、PHY以太网详解&#xff08;一&#xff09;-MAC/PHY/MII/RMII/GMI…

面向对象编程:深入PHP的封装、继承和多态性!

文章目录 面向对象OOP的核心概念定义类、创建对象构造函数和析构函数访问修饰符继承方法重写接口和抽象类静态方法和属性魔术方法 错误处理错误处理概述错误级别异常处理自定义异常设置错误处理忽略错误错误日志断言 总结 面向对象编程&#xff08;OOP&#xff09;是一种编程范…