最近一直在搞CDC (clock domain crossing) 方面的事情,现在就CDC的一些知识点进行总结。
做CDC检查使用的是Spyglass工具。以下内容转载自:Spyglass检查之CDC(2) | 码农家园 (codenong.com)
本文主要介绍cdc_setup过程中的rules——clock_info1,reset_info1, setup_clock01,它们报告设计中的时钟树,复位树。
报告设计中的时钟信号。spyglass可以识别出以下类型clock
描述 | 时钟类型 |
---|---|
普通输入时钟 | Primary Clocks |
黑盒(blackbox)或工艺库单元输出的时钟 | Black box clocks |
寄存器或工艺库单元输出的时钟 | Derived Clocks |
悬空的线或门控锁存器(门控未打开)输出的时钟 | Undrived Clocks |
除去以上情况,锁存器,三态器件或者组合逻辑输出的时钟 | Gated Clocks |
module top (d,q,clk1,sr): input [3: 0]d; input clk1, sr; output [3: 0]q; reg [3: 0]q: reg clk3; wire clk2, clk4, w1; BB(clk1, clk2, w1); always @(posedge clk1) q[0]=d[0]; always @(negedge clk2 q[1]=d[1]; always @(posedge clk3) q[2]=d[2]; always @(posedge clk1) if(sr==1) clk3=0: else clk3=-clk3; always @(posedge clk4) q[3]=d[3]; endmodule
clk1 是 Primary clock,clk2 是Black box clock,clk3 是Derived Clock,clk4 是Undrived Clocks
报告设计中的同步复位,异步复位和清除信号
描述 | 复位类型 |
---|---|
普通复位 | Primary Presets/Clears |
黑盒(blackbox)或工艺库单元产生的复位 | Black box Presets/Clears |
寄存器产生的复位 | Derived Presets/Clears |
悬空的线产生的复位 | Undrived Presets/Clears |
锁存器,三态器件产生的复位 | Gated Presets/Clears |
报告时钟源,时钟使能信号以及clock cone(不知道翻译成啥)。
设计中多个输入时钟通过选择器后只输出一个时钟,输出的时钟称为clock cone。