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

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

相关推荐
unicorn3130 分钟前
学习学习学习
学习
XGeFei1 小时前
【Fastapi学习笔记(3)】——资源的层级关系、安全性-幂等性、Field、工厂函数
笔记·学习·fastapi
星恒随风2 小时前
Python 基础语法详解(一):从表达式、变量到数据类型
开发语言·笔记·python·学习
tedcloud1234 小时前
cc-switch评测:多AI Coding Agent管理工具详解
数据库·人工智能·sql·学习·自动化
胡图图不糊涂^_^5 小时前
测试BUG篇
学习·bug·测试
humors2217 小时前
学习方法的系统梳理与实践应用
学习·学习方法
爱讲故事的7 小时前
操作系统第一讲复习:为什么学习操作系统,以及操作系统到底在做什么?
linux·开发语言·windows·学习·ubuntu·c#
胡图图不糊涂^_^8 小时前
测试用例篇——设计测试用例的方法
笔记·学习·测试用例·判定表法·正交法生成用例测试·等价类·边界值
Fanfanaas8 小时前
C++ 继承
java·开发语言·jvm·c++·学习·算法
飞翔中文网9 小时前
Java学习笔记之抽象类
java·笔记·学习