多时钟域系统设计的基本策略

1、尝试在数据和控制路径上实施时序优化策略

2、尝试去定义和产生多时钟域的组

3、尝试在不同时钟域之间增加同步器传递控制信号

4、尝试使用数据同步器(fifo、缓冲器)

消除CDC(跨时钟域):

1、避免亚稳态

2、使用MCP(多方案路径)方案

跨时钟边界着重考虑因素:

1、控制信号必须使用多级同步器进行同步处理

2、控制信号必须是没有毛刺和竞争的

3、跨时钟域边界应该有单次转换

4、控制信号应该至少在一个时钟周期内保持稳定

3、使用fifo

4、使用格雷码计数器

5、设计分区:在多时钟域的设计中,使用时钟组的概念进行模块划分

控制信号路径和同步:

1、电平同步器:使用电平同步器的方式(两个或者三个触发器结构打拍)可以解决多时钟域之间交换数据的亚稳态问题。

2、脉冲同步器:脉冲展宽、两级同步、边沿检测

关键设计要点

  1. 脉冲宽度要求 :源时钟域的展宽后脉冲宽度必须大于1.5倍目标时钟周期,以确保能被稳定采样。

  2. 最小脉冲间隔:两个源脉冲之间需有足够间隔,等待前一个脉冲完成"同步-反馈"的整个握手过程,否则脉冲会丢失。

  3. 从慢时钟到快时钟:结构类似,但因目标时钟更快,采样更易成功,对脉冲间隔要求可能更低。

  4. 握手机制 :上述带反馈的结构本质上是一种握手协议,保证了可靠性,但引入了延迟。

3、MUX同步器: 解决多比特信号跨时钟域时可能出现的位偏移(Bit Skew)或采样不一致问题。在源时钟域用寄存器锁存待发送数据,在目标时钟域通过一个同步的控制信号来选择何时采样这组锁存的数据

相关推荐
qqqahhh2 小时前
harness engineering学习
笔记·学习
AnalogElectronic2 小时前
uniapp学习1,hello world 项目,打包到微信小程序,贪吃蛇小游戏
学习·微信小程序·uni-app
li星野2 小时前
大模型的定义、特点
学习
NULL指向我2 小时前
信号处理学习笔记5:卡尔曼滤波理论
笔记·学习·信号处理
wefly20172 小时前
零基础上手m3u8live.cn,免费无广告的M3U8在线播放器,电脑手机通用
前端·javascript·学习·电脑·m3u8·m3u8在线播放
movigo7_dou2 小时前
SIFT的一些内容
论文阅读·图像处理·学习·计算机视觉
少许极端2 小时前
算法奇妙屋(三十七)-贪心算法学习之路4
学习·算法·贪心算法·田忌赛马
鱼鳞_2 小时前
Java学习笔记_Day18(数据结构)
java·笔记·学习
JACK的服务器笔记2 小时前
《服务器测试百日学习计划——Day14:BMC基础与健康状态,为什么服务器排障不能只看OS》
运维·服务器·学习