断言(SVA)检查时钟尖峰毛刺

检测DUV产生时钟是否产生毛刺,特指同一仿真时间同时出现时钟clk的上升沿和下降沿的情况。

对于该clk,发现@(posedge clk)和@(negedge clk)只能分别检测正常时钟的上升沿和下降沿,无法检测出毛刺。但是@(posedge clk or negedge clk)  可以检测出毛刺。(也许@(clk)也可以,没试过)。

如果@(posedge clk or negedge clk) 然后$display("%h",clk);

正常时钟会是01交替:0101010101

毛刺时钟会是01交替但是毛刺的位置重复出现1:010101011(左边是毛刺)010101

通过这一点可以写断言检测毛刺:

//定义断言的属性
property glitch_check(signal);
  @(posedge signal or negedge signal);
  1 => ($past(signal) != signal);
endproperty

//使用断言
ast_clk_glitch: assert property(glitch_check(clk));

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值