路科验证学习笔记(V0_23)——使用task进行验证

  • ref :SV中增加了一种方式ref,指定为引用而不是复制。这种方式只能用在automatic的子程序中,这种参数的好处是在子程序中修改变量对调用它的模块随时可见。 其值是该变量的最后一次赋值。若一个变量连接到多个ref端口,会有竞争风险,因为多个模块的端口可能同时更新其值。

  • inout端口用于建模双向连接,多个inout端口驱动一个变量,sv会根据驱动器的值和强度决定最终信号的值。

  • fork…joinX 的区别
    在这里插入图片描述

    • fork…join: 必须等到ment1,ment2,ment3全部执行完之后,ment4才可以执行。
    • fork…join_any: 等到ment1,ment2,ment3之中任何一个执行完毕之后,ment4 可以执行
    • fork…join_none: ment4的执行与否不依赖于ment1,ment2和ment3,他们可以同步执行。
  • 局部数据存储 automatic作用

    • Verilog中由于任务中局部变量会使静态存储区,当在多个地方调用同一个任务时,不同线程之间会窜用这些局部变量。可能导致错误。

    • Systemverilog中,module和program块中,缺省使用静态存储;如果想使用自动存储分配(不会窜用),需加入automatic关键词。(一般都要加)

  • 对于router这个DUT,比较器比较的时候不能直接拿发生器产生的数据和DUT输出的数据比较,而应该拿DUT输入端口数据(也就是driver输出的数据)和输出比较。

  • 常见四种数组类型,哪些可以拿== !=作比较,定长数组,队列,动态数组。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

Arist9612

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

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

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

打赏作者

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

抵扣说明:

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

余额充值