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

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)或采样不一致问题。在源时钟域用寄存器锁存待发送数据,在目标时钟域通过一个同步的控制信号来选择何时采样这组锁存的数据

相关推荐
Aision_2 小时前
从工具调用到 MCP、Skill完整学习记录
java·python·gpt·学习·langchain·prompt·agi
剑飞的编程思维2 小时前
真实学习本质-坚持思考的人
学习
AI浩2 小时前
学习嵌入位置:面向小目标检测查询检索的噪声感知位置编码
人工智能·学习·目标检测
辞旧 lekkk6 小时前
【Qt】信号和槽
linux·开发语言·数据库·qt·学习·mysql·萌新
爱上好庆祝10 小时前
学习js的第七天(wed APIs的开始)
前端·javascript·css·学习·html·css3
风兮雨露11 小时前
VMware虚拟机(安装/绿色版)
学习
zl_dfq13 小时前
python学习8 之 【集合、datetime模块、字典】
学习
kdxiaojie13 小时前
U-Boot分析【学习笔记】(3)
linux·笔记·学习
MediaTea14 小时前
Scikit-learn:从数据到结构——无监督学习的最小闭环
人工智能·学习·算法·机器学习·scikit-learn
@杰克成14 小时前
Java学习26
java·学习·idea