【System Verilog and UVM基础入门23】SVA语法

本文深入介绍了System Verilog Assertions(SVA)的高级特性,包括使用`ended`结构、参数化检验器、选择运算符、`true`表达式、`$past`构造及各种重复运算符。通过这些工具,可以更精确地定义和验证序列,例如检查信号在特定时钟周期内的匹配和延迟。文章还涵盖了`and`、`intersect`、`or`、`first_match`、`throughout`、`within`等构造,以及如何在属性中使用系统函数和形参,实现更复杂的时序和逻辑验证。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 毛主席说过:没有调查就没有发言权。

《SVA介绍——学习SVA语法》系列第二讲

目录

1.16 "ended"结构

 1.17 使用参数的 SVA 检验器

1.18 使用选择运算符的SVA检查器

1.19 使用 true 表达式的 SVA 检验器

1.20 "$past"构造

 1.20.1 带时钟门控的$past 构造

1.21 重复运算符

1.21.1 连续重复运算符[*]

1.21.2 用于序列的连续重复运算符[*]

 1.21.3 用于带延迟窗口的序列的连续重复运算符[*]

1.21.4 连续运算符[*]和可能性运算符

1.21.5 跟随重复运算符[->]

 1.21.6 非连续重复运算符[=]

1.22 "and"构造

 1.23 “intersect”构造

1.24 ”or“构造

1.25 “first_match”构造

1.26 “ throughout”构造

1.27 “within”构造

1.28 内建的系统函数

1.29 "disable iff"构造

1.30 使用“intersect”控制序列的长度

1.31 在属性中使用形参

1.32 嵌套的蕴含

1.33 在蕴含中使用 if/else

1.34 SVA中的多时钟定义

1.35 “matched”构造

1.36 “expect”构造

1.37 使用局部变量的 SVA

1.38 在序列匹配时调用子程序



本文还是延续上一篇的风格,语言内容尽可能简单明了,有问题大家相互讨论,共同进步。需要电子书的朋友可以给我发邮件。tommi.wei@qq.com

1.16 "ended"结构

到 目 前 为 止 , 定 义 的 序 列 都 只 是 用 了 简 单 的 连 接(concatenation)的机制。换句话说,就是将多个序列以序列的起始点作为同步点,来组合成时间上连续的检查。 SVA 还提供了另一
种使用序列的结束点作为同步点的连接机制。这种机制通过给序列名字追加上关键词“ended”来表示。例如ÿ

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值