C/C++教程

Spyglass CDC工具使用(二)

本文主要是介绍Spyglass CDC工具使用(二),对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

  最近一直在搞CDC (clock domain crossing) 方面的事情,现在就CDC的一些知识点进行总结。

做CDC检查使用的是Spyglass工具。以下内容转载自:Spyglass检查之CDC(2) | 码农家园 (codenong.com)

文章目录

  • Clock_info01
  • Reset_info1
  • Setup_clock01

本文主要介绍cdc_setup过程中的rules——clock_info1,reset_info1, setup_clock01,它们报告设计中的时钟树,复位树。

Clock_info01

报告设计中的时钟信号。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

Reset_info1

报告设计中的同步复位,异步复位和清除信号

 

 

描述复位类型
普通复位 Primary Presets/Clears
黑盒(blackbox)或工艺库单元产生的复位 Black box Presets/Clears
寄存器产生的复位 Derived Presets/Clears
悬空的线产生的复位 Undrived Presets/Clears
锁存器,三态器件产生的复位 Gated Presets/Clears

 

 

 

 

 

 

Setup_clock01

报告时钟源,时钟使能信号以及clock cone(不知道翻译成啥)。
设计中多个输入时钟通过选择器后只输出一个时钟,输出的时钟称为clock cone。
在这里插入图片描述

这篇关于Spyglass CDC工具使用(二)的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!