首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >将带延迟的SystemVerilog断言转换为不变规格

将带延迟的SystemVerilog断言转换为不变规格
EN

Stack Overflow用户
提问于 2016-11-22 23:39:44
回答 1查看 203关注 0票数 1

我想把一个带有延迟的SystemVerilog断言转换成一个正式验证器的不变规格。合成器在下面的代码行中给出了##1的语法错误。

代码语言:javascript
复制
assert property ( ( req1 == 0 ) ##1( req1 == 1 ) ##1 !( req2 == 1 ) || ( gnt1 == 0 ) );

有几个属性需要验证,并且有延迟。我目前正在尝试使用合成器将它们转换为正式的(SMV)模型规范,该合成器可以很好地处理不涉及延迟的属性。我可以为这个正式的验证器工具建模延迟吗?如果是这样的话,是怎么做的?

EN

回答 1

Stack Overflow用户

发布于 2017-02-18 05:14:24

一种方法是在Verilog中显式地对信号的延迟版本进行建模,然后您可以使用不具有时间依赖性的断言。

对于您的示例:

代码语言:javascript
复制
assert property ( ( req1 == 0 ) ##1( req1 == 1 ) ##1 !( req2 == 1 ) || ( gnt1 == 0 ) );

变成:

代码语言:javascript
复制
reg req1_r,req1_rr;

always @(posedge clk) begin
   req1_rr <= req1_r;
   req1_r <= req1;
end

assert property ( !(( req1_rr == 0 ) && ( req1_r == 1 )) 
               || !( req2 == 1 ) || ( gnt1 == 0 ) );
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/40745984

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档