【数字后端设计】CPPR详解

定义:CPPR(CRPR)Clock Path Pessimism Removal(Clock Reconvergence Pessimism Removal),中文名“共同路径悲观去除”。它的作用是去除clock common path上的悲观量

STA在分析setup timing时,clock launch path会选择路径的max delay,clock capture path则会选择路径的min delay。但对于common path,在计算setup的时候,作为launch path使用的是max delay,作为capture path使用的是min delay,这会导致结果过于悲观,所以需要去除这个计算的悲观量

在这里还要讲一下OCV的概念!后续也会详细介绍相关知识,具体见阅读下一篇文章:https://blog.csdn.net/m0_61003348/article/details/126694087

OCV全称是on chip variation,同一片wafer上,因为片上工艺的误差,导致不同位置的chip性能不一样。同一块chip,不同位置上的同一类cell的性能也会有差异。这些差异直接表现就是timing相关的东西(delay、transition等)。为此我们引入OCV的概念,用来在设计阶段模拟这些片上误差。为此,引入了derate值的概念。

考虑OCV的前提下,setup check时,工具会给launch clock pathdata path设置一个late(大于1)的derate值,给capture clock path设置一个early(小于1)的derate值,导致launchcapture common pathdelay值有差别

但是同一个RC corner下,不论是计算launch clock path还是capture clock path,一段时间以内common path上的delay一定是相同的,此时需要把这段悲观度去除

innovus命令: set_analysis_mode -cppr {none|both|setup|hold}

CPPRsetup影响分析:

 

时钟周期为5.49ns,且路径为单周期检查

不考虑OCV影响,此时setup没有时序违例

Setup slack = 1.2+0.86-0.35-1.2-0.8-5.2+5.49 = 0

考虑OCV影响,对launch clock pathdata path1.2derate,对cellsetup time1.1derate,对capture clock path0.9derate

Setup slack = 1.2x0.9+0.86x0.9-0.35x1.1-1.2x1.2-0.8x1.2-5.2x1.2+5.49 = -1.681

考虑OCV基础上同时考虑CPPRCPPR补偿值 = 1.2x1.2-1.2x0.9 = 0.36

Setup slack = 1.2x0.9+0.86x0.9-0.35x1.1-1.2x1.2-0.8x1.2-5.2x1.2+5.49+0.36 = -1.321

 可以看出,对于setup而言,不考虑CPPRsetup时序会过于悲观

CPPR对hold影响分析:

 不考虑OCV影响,此时hold没有违例

Hold  slack = 0.25+0.6+1.7-0.25-0.75-1.25= 0.3

考虑OCV影响,对launch clock pathdata path0.9derate,对cellhold time1.1derate,对capture clock path1.2derate

Hold slack = 0.25x0.9+0.6x0.9+1.7x0.9-0.25x1.2-0.75x1.2-1.25x1.1 = -0.28

考虑OCV基础上同时考虑CPPR CPPR补偿值 = 0.25x1.2-0.25x0.9 = 0.075

Hold slack = 0.25x0.9+0.6x0.9+1.7x0.9-0.25x1.2-0.75x1.2-1.25x01.1+0.075 = -0.205

 对于hold而言,不考虑CPPRhold时序也会过于悲观

CPPRSI影响分析 

分析setup时,由于capturelaunch clock在不同时钟沿采样,不能保证在同一个timing windowSI对公共路径的影响不一定是相同的,因此SIcommon path造成的delay不能通过CPPR抵消

分析hold时,由于capturelaunch clock在同一个时钟沿采样,同沿时钟对应的timing window一致,SI对公共路径的影响是相同的,因此SIcommon path造成的delay可以通过CPPR补偿来抵消

report_timingreport_crpr的区别

使用report_crprreport_timing报出来的CRP值是不一样的, report_timing 报出来的CRP值会略小于report_crpr report_crpr更准确,它的计算基于-from-to路径report_timing计算需要update timing,重新构建时钟网络,并计算所有的起点终点CRP值,增加大量计算工作。

report_timing使用timing_crpr_threshold_ps来降低计算量。CRP的值小于给定的timing_crpr_threshold_ps时,路径不做CRPR补偿,保留一定的悲观度,因此 report_timing报出来的CRPreport_crpr报出来的CRP值差距不会超过timing_crpr_threshold_ps的值

CPPR对后端设计指导意义

时钟common path应该尽可能长(分叉点尽可能往sink点长),这样CPPR补偿越大,对setuphold都有好处 !

  • 17
    点赞
  • 126
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
数字滤波器是数字信号处理中的一个重要组成部分,用于对数字信号进行滤波处理,以提取或去除特定频率范围内的信号成分。MATLAB提供了多种数字滤波器设计工具,包括IIR滤波器、FIR滤波器等。 数字滤波器设计的一般流程如下: 1. 确定滤波器类型:根据不同的应用需求,选择合适的滤波器类型,常见的有低通滤波器、高通滤波器、带通滤波器、带阻滤波器等。 2. 确定滤波器参数:根据滤波器类型和频率响应要求,确定滤波器的参数,包括通带截止频率、阻带截止频率、通带最大衰减、阻带最小衰减等。 3. 设计滤波器:根据滤波器参数,使用MATLAB提供的数字滤波器设计函数,如butter、cheby1、cheby2、ellip等,设计出滤波器的系数。 4. 评估滤波器性能:使用MATLAB提供的滤波器分析工具,如freqz、filter等,评估滤波器的频率响应、幅频特性、相频特性等性能指标。 5. 实现滤波器:将滤波器系数导出,或直接在MATLAB中调用滤波器函数,对数字信号进行滤波处理。 下面以设计一种IIR低通滤波器为例,详细介绍MATLAB的数字滤波器设计方法: 1. 确定滤波器类型:假设需要设计一个3阶Butterworth低通滤波器,通带截止频率为500Hz。 2. 确定滤波器参数:在MATLAB命令窗口中输入以下命令,确定滤波器参数: fs = 1000; %采样率 fc = 500; %通带截止频率 [b,a] = butter(3,fc/(fs/2),'low'); %使用butter函数设计滤波器 其中,fs表示采样率,fc表示通带截止频率,b和a分别为滤波器的分子系数和分母系数。 3. 设计滤波器:使用butter函数设计滤波器,具体命令如下: [b,a] = butter(n,Wn,ftype) 其中,n表示滤波器阶数,Wn表示数字滤波器的归一化截止频率,ftype表示滤波器类型,可选项有'low'(低通滤波器)、'high'(高通滤波器)、'bandpass'(带通滤波器)、'stop'(带阻滤波器)。 4. 评估滤波器性能:使用freqz函数绘制滤波器的频率响应曲线,具体命令如下: freqz(b,a) 该命令将绘制出滤波器的幅频特性和相频特性曲线。 5. 实现滤波器:将设计好的滤波器系数导出,或直接在MATLAB中调用滤波器函数进行滤波处理。例如,使用filter函数对一个长度为N的输入信号x进行滤波处理,具体命令如下: y = filter(b,a,x); 其中,y表示滤波后的输出信号,x表示输入信号,b和a为滤波器的系数。 注:IIR滤波器的设计需要注意滤波器的稳定性问题,即滤波器的极点位置必须在单位圆内,否则可能导致滤波器不稳定。MATLAB提供了多种稳定的IIR滤波器设计函数,如butter、cheby1、cheby2、ellip等。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

芯片后端工程师-ratel

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值